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FLOPPY DISK. 
- Fills time between coffee breaks 


- Makes a hard disk seem fast 


- Your computer appears busy 
(even if you aren’t!) 


- Wears out moving parts 


...for YOUR demanding tasks. 


SURPRISE! Neither is memory mapped, so they don’t 
affect your precious Main Memory. Both retain data indefi- 
nitely - even with the computer turned off. 

THE SEMIDISK SOLUTION. You could invest in a 
series of “upgrades” that turn out to be expensive band-aids 
without solving your real problem. Even those “Ac- 
celerator” and “Turbo” boards do little to speed up disk- 
bound computers. If your applications spend too much time 
reading and writing to disk (and whose don’t?), you won’t 
want to settle for anything less than a SemiDisk disk 
emulator. The SemiDisk comes in 512K and 2Mb capacity. 
More boards may be added to make up to an 8 Megabyte 
SemiDrive! 

SPEED THAT’S COMPATIBLE. PC, XT or AT, if you 
need speed, the SemiDisk has it. How fast? Recent ben- 
chmarks show the SemiDisk is from 2 to 5 times faster than 
hard disks, and from 25% faster (writing) to several times 
faster (random reads) than VDISK and other RAMdisk 
software that gobble up your main memory. 


MEMORY THAT’S STORAGE. Using our small exter- 
nal power supply, with battery backup, your data remains 
intact through your longest vacation or even a seven-hour 
power failure! 


the better fit... 


SEMIDISK Disk Emulator. 

- Gets that job done NOW 

- Makes a hard disk seem slow 

- Maximizes your productivity — 
with anything from databases 
to compilers 


- Totally silent operation 


CELEBRATE WITH US! Now, SemiDisk celebrates its 
fifth birthday with a special offer for IBM-PC owners. Buy 
a SemiDisk now and we’ll include an 8 MHz V-20 micro- 
processor (replaces the 8088) to make your new SemiDisk 
run even faster. Don’t need the V-20? We’ll take $20 off 
the price of your Battery Backup Unit! 


512K 2Mbyte 
IBM, PC, XT, AT $495 $ 795 
Epson QX-10 $495 $ 995 
S-100 SemiDisk II $795 $1295 
S-100 SemiDisk I $299 wen nwnnnnnnne 
TRS-80 II, 12, 16 $495 $ 995 
Battery Backup $130 $ 130 


Someday you’ll get a SemiDisk. 
Until then, you’ll just have to...wait. 


Semi1Disk 


SemiDisk Systems, Inc., 11080 S.W. Allen Blvd., Beaverton, Oregon 97005 (503) 626-3104 


If you thought all file managers 
were alike, think again. 
Think Btrieve. 


Btrieve stands out as the one file management 
system for programmers who are serious about 
productivity. With Btrieve, your programs can 
use simple subroutine calls to store, retrieve, and 
update records. It’s the file handling solution 
rich in functionality to meet your needs now 
and in the future, as your requirements 

grow and change. 


Bfast. With Btrieve you develop fast 
applications, with ease. Written in 
assembly language for IBM PC's, Btrieve 
uses b-tree algorithms with automatic 
balancing for fast, efficient file indexing. 


Bconnected. When your applications require 
networking, think Btrieve. A single version runs on all 
DOS 3 LAN’, including IBM PC Network and Novell 
Advanced NetWare. Btrieve is also available for 
Xenix and other multi-tasking operating systems. 


Broyalty Free. No royalty payments on your 
applications. Ever. 


Bsure. Btrieve comes with comprehensive 
documentation and unrivaled technical support for 
trouble-free software development. And you can 

add Xtrieve to supply your end users with even 

more, a menu-driven report writer and query 
system. 
Bsafe. Btrieve is the only file manager 
with automatic file recovery. Two levels of 
database integrity provide complete fault 
tolerance in the event of accidents or power 
failures. 


Bflexible. Develop your PC applications 
with the capabilities you need most. 
Capabilities such as: unlimited open files, 
unlimited records per file, 24 indexes per file 
and a maximum file size of 4 gigabytes. All 
this with Btrieve plus access from any 
programming language. 


Think Btrieve. Make your programming 
performance stand out. Contact SoftCraft. 


SoftCraft 


A NOVELL COMPANY 
P.O. Box 9802, #917 
Austin, Texas 78766 

(512) 346-8380 Telex 358 200 


Btrieve, $245; multi-user Btrieve, $595; Xtrieve, $245; 
multi-user Xtrieve, $595 (for report generation, add $145 for single-user and $345 for multi-user). 
Requires PC-DOS or MS-DOS 2.X, 3.X or Xenix. Btrieve and Xtrieve are registered trademarks of SoftCraft Inc. 
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Editor’s Page 


Sol Libes 


Will The 386 
Leapfrog The 286? 


It is estimated that by the end of the year 
more than 200,000 80386 systems will be 
running DOS applications. By the end of 
next year, that number may reach one mil- 
lion. The combination of higher clock 
speed, 80387 math coprocessor, and cach- 
ing circuitry enable these machines to run 
standard DOS and DOS applications at two 
to four times the speed of an IBM PC/AT. 
When 32-bit software is run, speed will im- 
prove by several times this amount. 

Three of the very early 386 hardware 
products are reviewed in this issue. We 
will be reviewing more in upcoming issues, 
including complete 386 systems, 386 ac- 
celerator cards, and 386 piggyback 
boards. 

OS/2, the new operating system for the 
PS/2 series from IBM/Microsoft, is still 
not here yet and is not expected for several 
more months. Although it will have added 
features such as multitasking, increased 
memory addressing, and larger disk drive 
management, it is nevertheless a 286 op- 
erating system. This means it will have 
limitations and problems and it will not be 
able to take advantage of the 386’s ar- 
chitecture. Steve Ballmer, manager of sys- 
tem software at Microsoft, has called the 
286 a “brain-damaged” processor. 

In the meantime, several 386 operating 
systems have already arrived. Two are re- 
viewed in this issue, and several more will 
be released shortly. We will be reviewing 
them and related products in future issues. 
The 386 is an excellent device for multi- 
user systems, and we can expect to see sev- 
eral implementations of UNIX. 

Some software publishers have taken 
another tack. They have written 386 ex- 
tensions to DOS. This approach enables a 
user to run standard DOS Version 3.2 as 
the operating system and to run one or 
more 386 32-bit application programs. 


Examples of such extensions are DESQ- 
view Version 2.0, the PharLap 386/DOS- 
Extender, and A.I. Architects OS/386 
DOS extension. 

A large number of 32-bit 386 software 
development packages have already been 
released. PharLap Software and Micro- 
soft have released 386 assembler/linker 
packages. MetaWare has introduced both 
C and Pascal compilers. And Lahey has 
released a 32-bit version of their popular 
FORTRAN-77. 

The combination of 386 hardware and 
software means that mainframe process- 
ing speeds and capabilities will now be 
available on desktop machines. Sources at 
A.I. Architects, for example, claim that 
the performance of its 386 Humming- 
Board running at 20 MHz executes the 
Dhrystone C benchmarks (registers) 5.8 
times faster than a DEC VAX-11/780, 1.3 
times faster than a DEC VAX-8600, and 
1.5 times faster than an IBM 4381-2. This 
XT/AT plug-in card contains 16/20 MHz 
386, 387, memory cache, and 2 to 24 
Mbytes RAM. 

There is a general feeling in the industry 
that software developers will leapfrog over 
the 286 and concentrate on developing 
software for the 386. The reason for this is 
that the 386 is designed for true multi- 
tasking whereas the 286 is not. IBM and 
Microsoft have already indicated that PC 
application software will require extensive 
modification to run in the multitasking 
protected mode of the OS/2 (a 286-based 
operating system). 

The 386 provides a third mode of opera- 
tion: the virtual mode, which allows multi- 
ple 8086 address spaces to be created, 
each protected from the others and from 
the operating system. Thus, most 8086 
applications will execute without modifi- 
cation, and no matter how badly behaved 
an application is, it will not affect other 
applications. This means that one can 
have several multiple terminate-and-stay- 
resident (TSR) programs (for example, 
Sidekick) without having a conflict, and 


the features of TSR programs can be 
greatly expanded. Communications pro- 
grams will be able to run comfortably in 
the background, and data interchange be- 
tween applications can occur without hav- 
ing to go in and out of each application. 

Application software reportedly will 
run more slowly under the OS/2-protected 
mode than it does under 386 DOS exten- 
sion software running in protected mode 
or virtual mode. 

The amount of application software 
that will be available to run under OS/2 
Version 1.0 will probably be limited, as 
many software developers see OS/2 as an 
interim product. 

Another interesting 386 development is 
the introduction of UNIX with Micro- 
port’s DOS-Merge/386, which allows the 
running of multiple MS-DOS programs in 
an emulation mode. These new UNIX im- 
plementations also include Ethernet con- 
trollers, TCP/IP, and Sun Microsystems 
NFS networking and X Window support. 
These last facilitate the movement of 
graphics-oriented displays around a net- 
work of dissimilar systems. § 


M/SJis Cheaper by the 
Dozen in 1988! 


Starting in January, Micro/Systems Jour- 
nal will come to you EVERY MONTH! 
That means you will get twice as many 
articles providing detailed, technical in- 
sight into PC systems integration. In fu- 
ture issues of M/S], look for special articles 
on: 


@ Local Area Network Systems 

@ Interfacing to PS/2 

@ Interfacing to OS/2 

© C Software Development Tools 
® PC Multiuser Operating Systems 
@ and much more 


Don’t miss a single issue! Turn to page 56 
and subscribe today! 
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ok at these BRIEF 2.0 enhancements! 


Main Features: 


e All new documentation with tutorials on basic editing, regular 
expressions and the BRIEF Macro Language. 


e Setup program for easy installation and configuration. 
(Requires no knowledge_of the macro language) 


_ © Increased speed for sophisticated operations like Undo and 
Regular Expression Search. 


e Expanded regular expressions, with matching over line 
boundaries. 


e More block types, with marking by character, line or column. 


¢ Command line editing (move cursor, add and delete 
characters, specify command parameters). 


e Support for more programming languages. 
¢ Optional borderless windows. 
e Enhanced large display support, including wider displays. 


e Reconfigurable indenting for C files 
(supports most indenting styles). 


Basic Features: 


¢ Full multi-level Undo 
Requires an | : e Windows 
at least 1954 Aa © oF compatipy p ; 
BRIEF is a trace e with ¢ Edit many files at once 
Solution Sy Mark of Un erWare, Ing 


of U ch 5: : ‘ d ; 
$18.8 trademark of Solition’¢ ¢ File size limited only. by disk space 
199 Systems, : — : : 
e Automatic language sensitive indentation 


News, Views & Gossip 


by Sol Libes 


Random Gossip & Rumors 

Don’t junk those old PC or XT clunkers! It 
is rumored that Intel is readying an XT ver- 
sion of its Inboard-386/AT card to sell for 
about $700 (with zero memory) and just 
under $1,000 with a Megabyte of RAM on 
board. Replace the old CGA display with a 
VGA card and display and the machine will 
run OS/2 as well, or better, than a new 
IBM PS/2 Model 50 costing more than 
three times the price. Or, try an XT re- 
placement 386 motherboard. There are al- 
ready a half-dozen available. (What a po- 
tential market! With about 9 million PCs 
and XTs waiting to be upgraded to the 386, 
expect to see specialty dealers whose only 
business will be reworking PCs and XTs.) 

Also look for Compaq to shortly intro- 
duce a 386-based portable computer to 
scoop IBM’s introduction of a 286-based 
portable. Two 386 portables are already 
being marketed by PC Discount (Hous- 
ton, Texas) and Storage System Engineer- 
ing Service (Santa Clara, Calif.). 

Paradise Systems (San Francisco, 
Calif.) is reportedly shipping sample 
quantities of a single-chip VGA display 
controller to OEMs. Several PC clone 
makers are expected to show machines at 
the November Comdex trade exhibition. 
These units will include this chip, along 
with 3%-inch drives, to run OS/2 with a 
PS/2-compatible BIOS. The question now 
is whether they will advertise these sys- 
tems as PC- or PS/2-compatible systems? 

IBM is expected to announce a replace- 
ment for the RT in February. It is rumored 
to be the PS/2 Model 90, which will use 
either a 20-MHz 386 or new RISC proces- 
sor and an extended VGA controller. It is 
expected to compete against the new Sun 
Microsystems RISC and DEC MicroVax- 
III systems. 

IBM also is expected to release versions 
3.4 and 3.5 of PC-DOS shortly. Version 
3.4 reportedly fixes some 3.3 bugs, and 3.5 
will contain drivers for new large capacity 
hard disk drives/controllers. 

Apple is said to be developing an 80386 
coprocessor card for its hot-selling new 
Mac-II system. Reports indicate that the 
Mac*II and Mac-SE are gaining signifi- 
cant acceptance in the corporate world. 

Word has it that Microsoft has begun 
development of a 386 version of OS/2, 


with possible release scheduled as early as 
the first quarter of 1989. 

Atari is rumored to be developing a new 
desktop system designed to serve the work- 
station market. However, Atari’s new sys- 
tem is based on the Transputer 32-bit mi- 
croprocessor from England rather than the 
Motorola 68020. The Transputer boasts 
performance that is four times better than 
the 68020. The big problem, however, may 
not be the hardware design but the soft- 
ware. First and foremost is the develop- 
ment of an operating system—the likeli- 
hood is that it will be a port of UNIX. 
There are reports that prototypes of this 
system have already been seen at Atari. 
Then again, there have been other times 
that Jack Tramiel has shown a prototype 
product that never made it into production. 

QMS (Quality Micro Systems of Mo- 
bile, Ala.) is said to be readying the first 
color laser printer for introduction by the 
end of this year. The price is expected to 
be somewhere between $20,000 and 
$30,000. 


The Business of Software and Micros 
Microsoft has been referred to as a “soft- 
ware monopoly.” This label probably 
comes from the company’s large number 
of recent acquisitions, and Bill Gates’ be- 
lief that there is a need for Microsoft to 
compete in virtually every software mar- 
ket. However, if one looks at the software 
sales figures, Microsoft is far from the 
number one market position needed for a 
monopoly. The title would better fit IBM. 

Datamation magazine’s recent study of 
software companies showed that Micro- 
soft ranked only eleventh in the field. Al- 
though sales for 1986 increased 60 percent 
over the previous year to more than $260 
million, Microsoft was far behind the lead- 
ers: IBM (more than $5.5 billion), Unisys 
($861 million), DEC ($560 million), NEC 
($507 million), Fujitsu ($389 million), 
Siemens ($387 million), Hewlett-Packard 
($375 million), Hitachi ($331 million), 
Nixdorf ($299 million), and Lotus ($283 
million). 

It should be noted that five of the top 
ten software companies in the survey were 
foreign, including three Japanese firms. 

By contrast, Datamation’s recent study 
of the top micro manufacturers indicated 


that of the top ten, only three were foreign 
companies, and two of those were Japa- 
nese. Naturally, IBM led the field ($5.65 
billion), followed by Apple ($1.8 billion), 
Olivetti ($1.3 billion), Tandy ($997 mil- 
lion), Unisys ($800 million), NEC ($697 
million), Compaq ($625 million), AT&T 
($600 million), Toshiba ($581 million), 
and Zenith ($548 million). 

Micros are now a substantial part of 
IBM’s business. Last year, IBM did in ex- 
cess of $48.5 billion in sales, of which the 
largest single area was still mainframe 
sales ($14.45 billion). Peripheral sales 
were second (more than $11.2 billion), 
and maintenance third (more than $7.4 
billion). Micros ranked fourth, and soft- 
ware sales ranked fifth. However, soft- 
ware showed the biggest growth for IBM 
last year and probably will over overtake 
IBM’s micro and maintenance business 
this year. While hardware prices have 
gone down, software prices have gone up. 


80386 Versus the 68020 

When IBM announced its PS/2 Model 80, 
a 386-based system, much earlier than ex- 
pected and began shipping units months 
earlier than expected, it was not to meet 
the competitive challenge offered by the 
Compaq DeskPro 386. Rather, it was Ap- 
ple’s Mac-II that had IBM worried. Apple, 
number two in the microcomputer game 
(see story below), showed a healthy sales 
increase of 11.1 percent last year com- 
pared to IBM’s small 2.7 percent increase. 
At the same time, Apple’s market share 
increased while IBM’s share decreased. 
Further, most of Apple’s share increase 
has been in the business area. By compari- 


son, Compaq ranks seventh in the micro 
race and is essentially an IBM cloner, 
which makes the company vulnerable to 
IBM’s changing marketing tactics. 

Both IBM’s and Apple’s new systems 
are based on 32-bit microprocessor chip 
sets; the Intel 80386 versus the Motorola 
68020. The systems are designed for mul- 
tiprocessing workstations with color 
graphics windowing user interfaces. If you 
compare their respective features and 
specs, you can note their similarities. IBM 
hopes that the PS/2 Model 80 with OS/2 
V1.1 will head off the Mac-II, in the same 
way the PC stopped the Apple-II’s ad- 
vancement into the business community in 
the early 80’s. The model 80 with OS/2 is 
designed to be a “Mac-II killer.” 

However, Apple is once again proving 
itself the technological leader in the PC 
marketplace. The Mac has grown from a 
plaything to a sophisticated system. For 
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example, Apple’s new Miultifinder soft- 
ware brings Presentation Manager-type 
multiprocessing to the Mac more than a 
year before it will appear on the IBM PS/ 
2. And Apple’s new HyperCard software 
introduces a new, powerful, easy-to-use, 
graphics-oriented database management 
system for the Mac. Business users now 
have another reason, beside easy-to-use 
desktop publishing and powerful graphics 
development, to buy the Mac. 

One of the most important features of 
these systems are their compatibility with 
the models that preceded them. In the case 
of IBM, it was compatibility with the PC/ 
AT (based on the 80286) and DOS. In the 
case of the Mac-II, it was compatibility 
with the Mac-I (based on the 68000). 
Both the PS/2 Model 80 and Mac-II can 
run software designed for their predeces- 
sors. However, OS/2 with the Presenta- 
tion Manager will require substantial re- 
writes of current DOS software while 
Apple’s new Multifinder can multiprocess 
most of the old Mac software. 


On to the Next Generation 

Both Intel and Motorola are already hard 
at work on their next generation of micro- 
processors, and IBM and Apple are de- 
signing their next .generation of micros. 
Intel is rumored to have already shipped 
early prototype 80486 samples to IBM. 
Intel is promising that the 486 will be soft- 
ware-compatible with the 386. 

Motorola, on the other hand, has dis- 
closed that its 78000, will be a non-compat- 
ible, RISC-based device. Motorola is tak- 
ing a real gamble here by abandoning 
software-compatibility. Intel discovered 
this several years ago when it introduced 
the 432, a 32-bit chip set, with a very ad- 
vanced architecture. But, the 432 was not 
compatible with Intel’s popular 8086 16-bit 
device. System designers had to start from 
ground zero on a whole new learning curve, 
and very few companies were willing to 
make the necessary long-term investment. 
With so few companies interested in the 
432, Intel could not make its own invest- 
ment in support for these devices. 

Fortunately, Intel recognized its mis- 
take early and redirected its R&D efforts 
into the 286 and 386. Although the 286 
and 386 represented a step backward in 
terms of technology when compared to the 
432, they proved to be what the market 
wanted and they put Intel back into profit- 
ability. Let’s hope that the Motorola 
78000 does not end up impaled on the cut- 
ting edge of technology the way the Intel 
432 did. 


0S/2 News 
Microsoft is waging a promotional cam- 
paign for OS/2 and its Presentation Man- 
ager, the scale of which we have never 
before seen in the personal computer in- 
dustry. Almost a year before the product 
was to be released, Microsoft began con- 
ducting seminars and selling software de- 
veloper kits, which included a beta version 
of OS/2 Version 1.0 (without the Presen- 
tation Manager). By early July, they had 
already sold an estimated 2,000 developers 
kits at $3,000 each, and they will probably 
sell another 2,000 kits in the fall. That’s 
about $12 million in sales for a beta prod- 
uct! I guess that goes to prove that ad- 
vertising and sales promotion really pay. 
Microsoft and IBM will have had 4,000 
beta testers actually paying to help them 
develop, debug, and tune the product. 
Microsoft began shipping copies of its 
Presentation Manager specifications to 
software developers in mid-August. It is a 
three-volume set weighing eight pounds! 
No word as yet on when Microsoft plans 
to ship the product. 


PS/2 News 
As reported in the last issue, overall sales 
of the PS/2 Models 30, 50, and 60 have 
been lackluster so far although corporate 
acceptance seems promising. Many deal- 
ers are overstocked and offering discounts. 
Although the typical discounts have been 
in the order of 30 percent, discounts as 
great as 35 percent have been advertised. 
Sales are expected to pick up with the 
release of the OS/2 operating system, the 
availability of more Micro Channel plug- 
in boards, and the introduction of applica- 
tion software that takes advantage of the 
PS/2’s Micro Channel. However, by then 
many clone makers will be offering high- 
performance AT-compatibles and 80386- 
based systems with many PS/2-compati- 
ble features (e.g. 1.44 Mbyte 3'4-inch 
floppy disk drives, VGA display control- 
ler) and running OS/2. . 


PS/2 Clone News 
IBM is offering a license to PC clone mak- 
ers for the PS/2 utility patents. This li- 
cense would allow manufacturers to pro- 
vide the same functional features as the 
PS/2 systems, but would not provide 
copies of the design technology (such as 
chip design, microcode, and so on). In 
other words, IBM will not license its hard- 
ware-design patents, copyrights, and 
trademarks for the Micro Channel. 
Reports are that IBM is asking for roy- 
alty payments of one to three percent. The 


one percent royalty would be on all cloned 
products (PC, XT, AT, and PS/2 with ret- 
roactive payments), while the three percent 
royalty would apply to cloners who wish 
only to license selected products. IBM has 
reportedly had licensing discussions with 
several Taiwanese and Korean manufac- 
turers, as well as U.S. and Japanese firms. 

In the meantime, Chips and Technolo- 
gies is already sampling a chip set for the 
PS/2 Model 30 and is promising samples 
of chip sets for the Models 50/60 and 
Model 80 by year end. 

Paradise Systems is already shipping 
production quantities of a VGA chip to 
OEMs. It appears likely that this chip will 
appear on plug-in cards for PC/XT/AT 
systems and on new 286 and 386 system 
boards. These products are expected to be 
shown at Comdex in late November. 

In an effort to avoid legal suits, PC clone 
makers are expected to implement the non- 
patented features of IBM’s PS/2 (VGA, 
32-inch disks, OS/2) on high-speed AT- 
compatibles before turning to IBM’s costly 
licensing and expensive development of Mi- 
cro Channel emulation. It seems unlikely 
that clone makers will begin shipping Mi- 
cro Channel compatibles until early °89. 
When they do ship, these systems should 
offer enhancements over IBM’s PS/2 Mi- 
cro Channel machines. 

Cloners (such as Compaq, Tandy, Ze- 
nith, PC’s Limited, and so on) are cur- 
rently enjoying very strong sales of en- 
hanced high-speed AT compatibles. 
Industry sources indicate that these com- 
panies are well along in developing Micro 
Channel-compatible prototypes. However, 
strong sales of enhanced ATs are expected 
to continue well into 1988, giving clone 
companies plenty of time to evaluate their 
PS/2 compatible system plans. 


RISC on the PC 

No sooner did Sun Microsystems intro- 
duce its new top-of-the-line Sun-4 series of 
RISC-based 10-Mips machines, which 
claim performance equal to a VAX 8800 
system, than Definicon Systems 
(Newbury Park, Calif.) introduced a co- 


processor board for the PC using the same 
chip set. Definicon was able to do this be- 
cause the chip set was developed jointly by 
Sun and Fujitsu, with Sun offering licens- 
ing of the chip set, operating system, and 
software development tools to others. The 
Definicon coprocessor board will run un- 
der DOS using the PC for all I/O. This will 
bring a new level of performance to the PC 
for applications such as CAD, which 
sorely needs it. § 
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Announcing - the database 
development system that 
you designed. 


® 2 


C PROGRAMMERS- 
We asked what you 
wanted in a database 
development system and 


RAIMA’S COMMITMENT TO YOU: No Royalties, Source 
Code Availability, 60 days FREE Technical Support and 


we built it! our 30-day Money-Back Guarantee. Extended services 
db_VISTA III™ is the database development system for available include: Application Development, Product 
programmers who want powerful, high performance Development, Professional Consulting, Training Classes 


DBMS capabilities ... and in any environment. Based on and Extended Application Development Support. 
the network database model and the B-tree indexing 
method, db_VISTA III gives you the most powerful and HOW TO ORDER: Purchase only those components 


efficient system for data organization and access. From you need. Start out with Single-user for MS-DOS then 
simple file management to complex database structures add components, upgrade ... or purchase Multi-user 
with millions of records. db_VISTA III runs on most with Source for the entire db_VISTA III System. 


computers and operating systems like MS-DOS, UNIX, It’s easy... call toll-free today! 
VAX/VMS and O$S/2. It’s written in C and the complete 
source code is available, so your application perfor- 

mance and portability are guaranteed! With db_VISTA 


IJ you can build applications for single-user microcom- 
puters to multi-user LANs, up to minis and even main- 


RELATIONAL DBMS 
TABLE 1 INDEX TABLE 2 


Sas i Ean 


NETWORK MODEL DBMS... db__VISTA™ 
RECORD 1 RECORD 2 db_VISTA out-performs 


Crema relational DBMS’s with direct 
frames. Overhead oe DI access to data and less data 
showninred | B | redundancy. Your applications 

and pink. 


run faster and more efficiently! 


aM 


The db_VISTA III“ Database Development System 


J ab_vistA™: The High Performance DBMS 


The major features include: A runtime library of over 100 functions. 
* Multi-user support for LANs and multi-user * Operating systems: MS-DOS, UNIX V, 


db__VISTA III™ Database 
Development System 


computers. XENIX, VMS, OS/2. " i 
* Multiple database access. ¢ C Compilers: Lattice, Microsoft, IBM, popiep atl $595 55960 
* File and record locking. Aztec, Computer Innovations, Turbo C, _QUER $595 - 3960 
* Automatic database recovery. XENIX, and UNIX. db. REVISE $595 - 3960 
* Transaction processing and logging. © LAN systems: LifeNet, NetWare, PC Net- _ 
* Timestamping. work, 3Com, SCO XENIX-NET, other NET- on 
* Database consistency check utility. BIOS compatible MS-DOS networks. db_VISTA File Manager Starts at $195 
* Fast access methods based on the network 


database model and B-tree indexing. Uses db_QUERY:” The SQL-based Query. We'll answer your questions, help 


both direct “set’’ relations and B-tree in- © Provides relational view of db_VISTA ; 
dexing independently for design flexibility applications. determine your needs and get you started. 
and performance. * Structured Query Language 
* An easy-to-use interactive database access *_C linkable. Cc ALL TOD AY! 
utility. * Predefine query procedures or run ad-hoc (ERE | 
* File transfer utilities for importing/export- queries ‘‘on the fly”. Keaetzog 1 eo 800-db-RAIM A 


ing ASCII text and dBASE II/III files. 
A Database Definition Language patterned db_.REVISE™: The Database 


. 


(that’s 1-800-327-2462) 


RAIMA 


CORPORATION 


3055 112th Avenue N.E., Bellevue, WA 98004 (206)828-4636 
Telex: 6503018237MCIUW FAX: (206)828-3131 


after C. Restructure Program, 
* Virtual memory disk caching for fast * Redesign your database easily. 
database access. * Converts all existing data to revised design. 


All components feature royalty-free run-time distribution, source code 
availability and our commitment to customer service. That’s why corporations 
like ARCO, AT&T, Hewlett-Packard, IBM, Northwestern Mutual Life, UNISYS 
and others use our products. 
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ANNAN 


We welcome your letters, with their comments, compliments, 
criticism, and suggestions. We do not have the staff to answer all 
letters personally. All letters become the property of M/SJ and 
may be subject to editing. We do not print letters that do not 
include a name and address. 

Please send your letters to: Micro/Systems Journal, Box 1192, 
Mountainside, NJ 07092. 


Listing 1 


BATch INTERaction allows an MS-DOS batchfileto prompt the 
user forasingle character, and to choose its next action 
based on user's response. It sets the ERRORLEVEL according 
to response given by the user; and takes advantage of the 
batch facility's ability to take alternate actions basedon 
the ERRORLEVEL's value. 


To use, command line BATINTER arg1arg2...argNis placedin 
abatchfile, where: 


arg1is anoptional string of characters takenasatable 
of valid single-character responses fromuser. If omit- 
ted, 0123456789 is assumed. Maximumtable size is 80 
characters. arg2...argN are optional strings compris- 
ing prompt to be displayed when program is ready for 
single-character response. If omitted, Character ? is 
assumed. Maximum length of prompt is 80 characters. 


Examples: 


BATINTER ZQPD (Z)eke, (Q)uinn, (P)at, or (D)an? 
BATINTER JBLMRX 
BATINTER 


In the second example, default prompt will be used, and in 
the third example, the default table and default prompt 
will be ineffect. When BATINTER runs, it displays the 
prompt and waits for the user to type a single character that 
matches a character inthe table. When it receives amatch- 
ing character, BATINTER immediately sets the ERRORLEVEL 
equal to off set of matching response in the table and termi- 
nates. Inthefirst example above, BATINTER would wait fora 
Z,Q,P,orD. If the user types Z, the ERRORLEVEL would be 
set to0.IfQis typed, ERRORLEVEL will be setto1, andso 
on. Ina batchfile, the sequence 


BATINTER arg1arg2...argN 
IF ERRORLEVEL n GOTO a 

IF ERRORLEVEL n-1 GOTO b 
IF ERRORLEVEL n-2 GOTO c : 


will cause the next action taken in batchfileto be deter- 
mined by the user's response to BATINTER's prompt. Note 
that successive tests of ERRORLEVEL should be from highest 
to lowest, because expression ERRORLEVEL k evaluates to 
TRUE if value of ERRORLEVEL is equal to or greater thank. 
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Ask Questions and 

Get Resonses in 

Batch File Modifications 

Dear M/SJ: 

I found Bill Roger’s program (‘‘Asking Questions and Getting 
Responses in an MS-DOS Batch File,” M/SJ, May/June 1987, 
pp. 62-64) useful and ingenious. My thanks to him for sharing it, 
and to you for printing it. Because I am currently using Mix C 
(Version 2.5.2), I had to make some changes to the program. 

I also removed as many nonstandard usages as possible. Unfor- 
tunately, unbuffered keyboard input and visual display output 
could not be accomplished without resorting to nonstandard calls 
(see highlighted comments in Listing 1). 

The most substantive change was replacing the line referring to 
the function strchr (bottom of page 63) with a for statement. 
Apparently strchr is a nonstandard function, and is not supplied 
with all C compilers. I also tightened the code, changed variable 
names, enhanced the commenting, and made other aesthetic ad- 
justments. (See Listing 1.) 

Sidney L. Sanders 

Genesee NY 


#include (stdio.h) 
int errlev=-1; /* ERRORLEVEL returned to MS-DOS */ 
int index; /* Index for accessing array elements */ 


char dfprompt{]=”Character? ”; /* Default prompt */ 

char dfrsptab{}]=”’0123456789”; /* Default response table */ 
char resp; /* Single-char response from user */ 

char *matchptr; /* Pointer to matching char in response 
table */ 

char prompt[81]; /* Prompt string */ 

char rsptab[81]; /* Response table */ 


main(argc,argv) 
int argc; 
char *argv[]; 

( /* Begin main */ 


if(arge(2) 

strcepy(rsptab,dfrsptab); /* Default table */ 
else 

strcpy(rsptab,argv[1]); /* User-supplied table */ 
if(argce)2) 


for (index=2;index(arge;index++){ /* User-supplied prompt 
*/ 
strcat(prompt,argv[index]); 
strcat (prompt,” ”);} 
else 
strcpy(prompt ,dfprompt); /* Default prompt */ 
printf("%s ”,prompt); 
while(errlev(0){ /* Find char in table that matches response 
*/ 
printf(”\b \b”); /* Erase unmatched response */ 
resp=getch(); /* NONSTANDARD unbuffered keyboard read */ 
putch(resp); /* NONSTANDARD unbuffered vdu out */ 
for(matchptr=rsptab;*matchptr!=respéé*matchptr!='\ 
O';matchptr++); 
if(*matchptr!='\0') /* 
pointing */ 
errlev=(int)(matchptr-rsptab);} /* to a NUL, it's point- 
ing to */ 
print£f(”\n"); /*® a 
rsptab */ 
exit(errlev); /* set ERRORLEVEL and exit */ 
} /* End main */ 


If matchptr isn't 


matching char in 


Sidney L. Sanders 
Geneseo, NY 
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Lahey Computer Systems, Inc. 
Sets a New FORTRAN Standard! 


Introducing the latest addition to our line of FORTRAN Language Systems— 
Lahey Personal FORTRAN 77. 


What you Get With 
Lahey Personal 
FORTRAN 77: 


Lahey Experience. 
We are experts in designing 
and implementing FORTRAN 
Language Systems. Lahey 
has been producing 
mainframe implementations 
since 1967 and a PC 
FORTRAN (F77L) since 198 
In fact, F77L was named thi 
“EDITOR’S CHOICE” among PC™ 
FORTRANSs by PC Magazine. This 2 
year span of specialization has been — 
incorporated into the design of our "I 
revolutionary Lahey Personal FORTRAN 77. — 


LAHEY SLASHES COMPILATION TIME. : 
Compilation times (in seconds) for Vieiane Program (WHETS3H.F FOR) 


Test conducted on 1BM AT running at 6Mhz with 80287, 


Lahe' Personal FORTRAN 77 Version 1.0 ($95) 11.57 
[___Microsoft FORTRAN Version 4.0 ($450) | 54.08 


R [Ryan McFarland ForTRAN version 2.21 ($595) | [Ryan McFarland ForTRAN version 2.21 ($595) | FORTRAN Version 2.21 ($595) 88. 9 


Customer Support: 


Our philosophy is that customer relationships begin, rather than end, at the 
point of sale. Services include free technical support, electronic bulletin board 


for fast service and information access, and newsletters to keep you up to 
date. 


Purchasing the Lahey Personal FORTRAN 77 gives you our 
FORTRAN experience, a feature loaded product, industry leading 
compilation speed, and quality technical support; all for $95. 


International Representatives: Canada: Barry Mooney & Assoc., Tel. (902)6652941 @ England: Grey Matter 
Ltd., Tel. (0364)53499 @ Switzerland: DST Comp. Services, Tel. (022)989188 ¢ Denmark: Ravenholm Computing, 
Tel. (02)887249 @ Australia: Comp. Transitions, Tel. (03)5372786 @ Japan: Microsoftware Inc., Tel. (03)813822 


MS-DOS & MS FORTRAN are trademarks of Microsoft Corporation. 


If you want to program in FORTRAN - Lahey is the Source 


0 Please send me ___ Lahey Personal ENCLOSED 
FORTRAN 77 copies @ $95.00 eacn __ Check __ Visa __ Master Card __ AMEX 
Disk Format __ 51/4" _ 32" a Number 
Add $2.50 for shipping and Expiration Date 
handling per unit a Signature 
Nevada residents add Name 
applicable tax ee Company - 
TOTAL ENCLOSED Address 
SEND ME INFORMATION: City - 
Lahey Personal FORTRAN 77 State Zip 
OA future release not requiring math Phone 


coprocessor 
[] LCS Software Products 


Send to: Lahey Computer Systems, 
POB 6091, Incline Village, NV 89450-6091 


Feature Loaded: 


e@ Full implementation of the 

ANSI X3.9-1978 FORTRAN 

Standard 

Fast Compilation (see chart) 

Popular Language 

Extensions highlighted in the 

manual 

Source On-Line Debugger 

English Diagnostics and 

Warning Messages 

LOGICAL*1, LOGICAL*4 

INTEGER*2, INTEGER*4 

REAL*4, REAL*8, and 

DOUBLE PRECISION 

COMPLEX*8, COMPLEX*16 

Recursion 

31-Character Names 

Trailing Comment 

Cross Reference and Source 

Listings 

64 KB Generated Code 

64 KB Stack Storage 

64 KB Commons, Constants 

and Saved Local Data 

Math coprocessor 

requirement gives maximum 

performance 

350 Page User Manual 
SYSTEM REQUIREMENTS: 

256K Ram MS-DOS (2.0 or later) 


Math Coprocessor Chip (8087 or 80287) 


$ 


Lahey is setting the 
PC FORTRAN Standard. 


TO ORDER 


1-800-548-4778 


Lahey Computer Systems, Inc. 
P.O. Box 6091 
Incline Village, NV 89450 
Telephone: (702) 831-2500 
TELEX: 9102401256 


Lahey 


Computer Systems CY 


C Forum 
Don Libes 


varargs 
—Varying 
Arguments 


This column features tips and techniques 
for using the C language productively. It 
discusses typical problems with using C 
and their solutions. Reader suggestions, 
comments, and questions are encouraged. 
Address them to “The C Forum,” Micro/ 
Systems Journal, Box 1192, Mountain- 
side, NJ 07092. 


“varargs” is the name of a package that 
allows one to write portable code that 
passes varying numbers and types of argu- 
ments to a function. 

C, of course, already lets you pass arbi- 
trary parameters, in spite of how you may 
have them declared. (It’s not a bug, it’s a 
feature!) However, doing it portably is dif- 
ficult because bypassing the C parameter 
mechanism requires understanding and 
handling of each machine’s architecture. 

Some implementations push param- 
eters on the stack going down. Some do it 
going up. Depending on the type of pa- 
rameter, a different amount of space may 
be pushed. Some systems do not even use a 
stack but pass all parameters through reg- 
isters. And some machines use a combina- 
tion of both stack and registers. 

Because of this variety of implementa- 
tions, there is no standard way, for exam- 
ple, to figure out how many arguments 
have been passed. Popular conventions for 
doing so include: (1) passing the number 
of arguments as the first argument, (2) 
terminating the argument list with a spe- 
cial value, such as NULL, or (3) providing 
a way of indirectly deducing the number 
of arguments (for example, by counting 
the %s in a printf{ ) format). 

C’s approach to parameter types is no 
different than the way it handles the num- 
ber of parameters. The compiler simply 
doesn’t check that they match between 
caller and callee. No information is passed 
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as to what types the calling subroutine 
used. If you don’t use /int, you are on your 
own. 

Compiler writers would have you be- 
lieve that efficiency is the reason why you 
can’t find out how many arguments you’ve 
been passed. However, many languages do 
support this. For example, some provide a 
system variable that contains the number 
of arguments used to call the current 
procedure. 

Certainly, stronger type checking in the 
original design would have helped im- 
mensely. For example, Ada and C++ 
handle much of the support for function 
overloading at compile-time. Whatever 
the reason for this lack, however, we must 
live with the result. 


Using varargs 
varargs provides a portable means of writ- 
ing and calling functions with varying ar- 
guments. It was designed by Andrew 
Koenig of Bell Labs and has been imple- 
mented for most implementations of C. 
As you will see, the syntax of varargs is 
unusual. It allows us to access parameters 
in unorthodox ways. By hiding it with 
macros, we gain the ability to handle vari- 
able arguments on any sensible architec- 
ture and C compiler, and to do so in a port- 
able manner. (There are machines for 
which varargs cannot be implemented, but 
then C doesn’t work very well on such ma- 
chines either.) 


Portable printf( ) 
printf() is a classic example of a routine 
that cannot be correctly declared in C. 
The problem is that we don’t know the 
types and number of all the arguments at 
compile-time. Most implementations of 
printf{) use nonportable mechanisms for 
reading the arguments, often doing it in 
assembler. It can, however, be written 
portably in C. A skeleton printf{ ) is shown 
in Listing 1. 

varargs.h is a header file that defines 
the macros necessary to use varargs. This 
is called stdarg.h in the current X3J11 
draft C standard. 


The comment /* VARARGS*/ is a direc- 
tive to /int. Lint will turn off argument 
type checking for the following function. 

All varargs subroutines take only one 
argument, va_alist. The declaration for 
va_alist is va_dcl (without a semicolon). 
If you already know some of the argument 
types, do not declare them. You must get 
them through the varargs package, 
anyway. 

va_list arg declares an object that will 
point into the argument list. We can step 
arg to the next argument in the list or 
move it back to the beginning of the list 
and start over. You can use any name—it 
doesn’t have to be arg. You can also de- 
clare multiple objects that can point to dif- 
ferent places in the argument list. 

To initialize arg to the beginning of the 
argument list, say va_start(arg). va_end- 
(arg) should be called at the end of pro- 
cessing the argument list, whether or not 
you want to reread it with va_start( ). 

To read the next argument, call va_ 
arg(). The first parameter is an object of 
type va_list. The second parameter 
should be the type of the expected object 
after the parameter casting rules have 
been applied. Thus, to read an integer, we 
use va_arg(arg,int). To read a float, we 
use va_arg(arg,double) since floats are 
promoted to doubles in function calls. 

In our printf(), we get the format by 
calling va_arg(arg,char *) since it is a 
string. next_type() (which is left to the 
reader as an exercise) returns the format- 
ting type of the next argument. From this 
we can infer the type of the argument. 


The Future of varargs 
It is possible to support varargs without 
having to worry about the automatic pro- 
motion problems. One solution is to have a 
C operator, promote( ), that takes a type 
and returns the type after parameter pro- 
motion. However, promote() requires 
compiler support, and it is not in the ANSI 
X3J11 draft C standard as of this date. 
varargs is called stdarg in the X3J11 
draft C standard. It originally appeared in 
AT&T and Berkeley versions of UNIX but 
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is now available in most C compilers. It is 
certainly easy enough to support, and if 
you don’t have it, you should ask your C 
compiler vendor for it, or try writing it 
yourself. 

It is likely that the final C standard will 
look slightly different from the mechanism 
described here. However, any changes 
should be minor syntactic differences. 


A Related Problem—dprintf( ) 

Suppose we already have printf{), but we 
would like to write a function that uses it 
underneath. I have in mind a function that 
I call dprintf(). dprintf() takes all the 
same parameters as printf(), with one ad- 
dition. This extra parameter is compared 
against a global int. If the parameter is 
larger than the global, printf{) is called, 
otherwise nothing happens. 

This function is especially useful for con- 
trolling diagnostics. If I want a lot of de- 
bugging information, I set global_error_- 
level to 10. Lower numbers print out less 
information. And if I don’t want any de- 
bugging information, I set it to 0 so that 
none of the dprintf{ )s output anything. 

By passing the debug level as an argu- 
ment to the program, I don’t have to re- 
compile the program in order to turn on 
any level of diagnostics. This code appears 
in Listing 2. 

Actually, this was my second attempt. 
My first attempt never made it past cc be- 
cause I could not figure out how to declare 
args. No matter how I declared it (char, 
int, char *, and so on) or passed it (args, 
c&args, *args), printf( ) never saw the sec- 
ond argument. What it did see was a lot of 
“stack junk.’? The problem was that 
dprintf( ) got the stack with a good list of 
arguments, but all that I could pass to 
print() was the address of my stack. I 
couldn’t pass the stack itself! 

My second version has the arguments 
stated explicitly. It, however, also has 
problems. First of all, I have arbitrarily 
limited myself to four arguments. No mat- 
ter what number I pick, there is always the 
possibility that it will be exceeded. The 
second problem is that I have declared ev- 
ery argument as an int. This actually 
worked pretty well since chars are always 
converted to ints, and pointers (the other 
thing that I print out frequently while de- 
bugging) fit into ints on my machine. 
Nonetheless, I could not print out doubles 
because they didn’t fit into ints, so I al- 
ways got the wrong answer. I didn’t want 
to declare all the arguments as doubles ei- 
ther, because then the ints would not be 
handled correctly. 
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Although it might appear that varargs 
could be useful here, it doesn’t completely 


‘solve the problem. varargs still requires 


that you determine the types of the argu- 
ments. I just wanted to pass everything on 
to printf( ) uninterpreted. 


vprintf( ) and Friends 

The solution to the problem is to use a set 
of routines that are defined to take var- 
args-style parameters as their arguments. 


mal parameters. Otherwise, varargs is a 
delight to use. varargs is already available 
in most C compilers, and it (or something 
very much like it) will definitely be in the 
ANSI C standard. § 


Don Libes is a computer scientist work- 
ing in the Washington, D.C. area. He 
works on artificial intelligence in robot 
control systems. 


These were also written 
by Koenig (who evidently 
did a lot of struggling 
with these same prob- 
lems). vprintf() is similar 
to printf(). Both have a 
(char *) format as the { 
first argument. However, 

instead of an optional list 


Listing 1 


/*VARARGS* / 


char t, 


#include <varargs.h> 
printf (va_alist) 
va_dcl/* No semicolon! */ 


va_list arg; 
*fmt; 


va_start(arg); 
fmt = va_arg(arg,char *); 


of untyped arguments 


such as printf{ ), vprintf{ ) 
has a second argument 


while (t = next_type(fmt)) { 
switch (t) { 


print_character(va_arg(arg,int)); 


declared to be of type 
va_alist. 

Does this look famil- 
iar? Yes, it is the same 
va_alist from the varargs 
package! Now we can cor- 
rectly rewrite dprintf{ ) as 
shown in Listing 3. } 

Just as with printf( ), 
there are two other variet- 
ies of vprintf( ). They are, 
naturally, vsprintf() and 
vfprintf{ ) (Listing 4). 


Listing 2 


char *fmt? 


case 's': 


case 'f': /* 


case 'c': /* character */ 
break; 
case ‘d': /* integer */ 


print_integer(va_arg(arg,int)); 
break; 

/* string */ 
print_string(va_arg(arg,char *)); 
break; 

float */ 

print_float (va_arg(arg, double) ); 
break; 


va_end(arg); 


dprintf(error_level,fmt,arg0,argl,arg2,arg3,arg4) 
int error level; 


+ . . int arg0,argl,arg2,arg3,arg4; 
Like with printf() and ; WOxgne i : 


Sprintf(), vprintf() and 
vfprintf() return the } 
number of characters out- 
put, while sprintf() and 
vsprintf() return a Listing 3 
pointer to the beginning /* 
of the output buffer. 


va_del 


{ 


Conclusion 

Passing varying argument 
may seem distasteful at 
first, but this is probably 
because it was not origi- 
nally possible to do so por- } 
tably. Nonetheless, it is a 
legacy of C. And done 
correctly, elegant func- 
tions such as printf{ ) are 
possible. 

Using varargs, it is al- 
ways possible to write 
portable code. The only 
pitfall you must be aware 
of is vararg’s use of C’s 
rules on promotion of for- 


Listing 4 


char *s, 
va_list args; 


FILE *stream; 
char *fmt; 
va_list args; 


_ 


va_end(args); 


char *vsprintf(s,fmt,args) 
*fmt; 


int vfprintf (stream, fmt,args) 


if (global_error_level >= error level) 


printf (fmt,arg0,argl,arg2,arg3,arg4); 


really dprintf(error_level,fmt,args...) */ 
dprintf (va_alist) 


int error_level; 
char *fmt; 
va_list args; 


va_start (args); 

error level = va_arg(args,int) ; 

fmt = va_arg(args,char *); 

if (global_error level >= error level) 


vprintf (fmt,args); 
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Turbo Pascal 


Corner 
Stephen R. Davis 


VAR Vanables 


I am sad to report that I have been caught 
in a lie. Sometimes you believe so strongly 
that something must be a certain way that 
it never occurs to you to check it out. For- 
tunately, I caught myself this time so that 
I can come clean before any of you embar- 
rass me. But first to the Turbo Pascal 
product news. 

I have yet to hear anything about the 
next version of Turbo Pascal, the one with 
the user interface found in the newer 
Borland languages. I doubt that much ef- 
fort is being expended in this direction 
considering the amount of programmer’s 
time going into the “Great Language 
Wars of 1987.” This, you may know, is the 
confrontation being waged between 
Borland and Microsoft. It started last year 
with the Campaign of the BASICs (Turbo 
BASIC versus Quick BASIC). 

Last summer, a second front was 
opened at C (Turbo C versus the soon to 
be introduced Quick C). Although good 
for programming in general, these cru- 
sades direct attention away from Turbo 
Pascal. This, in turn, makes it unlikely 
that a new version of Pascal will be intro- 
duced any time soon. (Now if Microsoft 
would just introduce Quick Pascal and 
turn this into a three front war!) In any 
case, I will relay any military intelligence 
on the topic as I intercept it. 


Turbo Optimizer 

After my last review I felt that if I re- 
ported on another product from the people 
at Turbo Power Software someone was go- 
ing to accuse me of being on their payroll. 
However, here I go again. 

Turbo Optimizer is a collection of three 
programs: Turbo Library Compactor 
(TLC), Turbo Object Optimizer (TOO), 
and Turbo Object Librarian (TOL). TOL 
is a librarian that allows the programmer 
to store commonly used code segments in 
such a way that they can be called up and 
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inserted into new programs without being 
recompiled. Since Turbo Pascal is so fast 
at compilations, this one did not excite me 
particularly, but the other two did indeed 
catch my attention. 

The Turbo Object Optimizer (TOO) is 
an execution optimizer for Turbo Pascal. 
Turbo is well known for its compilation 
speed but not for the quality of the object 
code generated. Although it is not bad, 
Turbo-generated machine code is not 
comparable to the code from a good op- 
timizing compiler. TOO accepts as input 
the .COM file that Turbo Pascal generates 
and attempts to improve it. TOO’s job is 
complicated by the fact that it does not 
have access to the source code, as an op- 
timizing compiler normally would. 

The Turbo Library Compactor (TLC) 
attempts to reduce the size of .COM files 
generated by Turbo Pascal by removing 
sections of “dead” code that no one calls. 
As noted in an earlier column, Turbo Pas- 
cal saddles each .COM file it generates 
with the entire 10K of Turbo library— 
whether the file uses any of it or not. We 
saw that users could avoid having the li- 
brary included by building a chain utility 
and creating .CHN files rather than .COM 
files; however, the TLC makes this trick 
less necessary because it automatically re- 
moves the majority of this library from 
small programs. It can also remove any 
user procedures that are not invoked 
anywhere. 

In practice, both the TOO and the TLC 
made a noticeable improvement. The 
TOO can increase speed by as much as 30 
percent, although 20 percent is about av- 
erage. Not much to get excited about per- 
haps, but this is a 20 percent increase in 
speed with basically no effort. The TLC 
reduces .COM programs an average of 
8K. For typical, rather small Turbo pro- 
grams this can represent a respectable de- 
crease. Both TOO and TLC can be applied 
to the same .COM for a double savings. 

A special “tiny” mode can reduce spe- 
cially written programs even further than 


that—some very small programs to as lit- 
tle as 100 bytes! This can be very useful 
indeed when using Turbo Pascal to build 
terminate-and-stay-resident programs 
such as those described in M/SJ, July /Au- 
gust 1985. 

TOO works only with programs gener- 
ated by PC-DOS Turbo Pascal, Versions 
3.00 and later. It requires a PC, XT, AT, 
or a compatible, and 256K of memory. 
Source code is available at extra charge. 
Order lines are open seven days a week at 
(800) 538-8157 (or, in California, [800] 
672-3470) ext. 830. Cost is $75 from the 
company, but I have seen it for as low as 
$65 from mail-order sources such as the 
Programmer’s Connection. 


VAR Variables 

The lie I mentioned above has to do with 
how Turbo Pascal passes arrays as argu- 
ments to subroutines. First a little back- 
ground. There are two ways to pass a pa- 
rameter to a function: by value or by 
reference. When passing by value, a copy 
of the parameter is passed to the subrou- 
tine. For example, assume the variable X 
contains the value 10. If X is passed by 
value, then the value 10 is passed to the 
subroutine. The subroutine does not have 
access to the original 10, but to a copy of 
it. When passing by reference, the original 
parameter is passed to the subroutine—no 
copy is made. In our example, the subrou- 
tine gains access to the original 10 by pass- 
ing the address of X. 

Pascal allows the user to specify 
whether passing is to be done by reference 
or value. In the absence of any indication 
to the contrary, Pascal passes by value; 
however, the programmer may override 
this by tacking the keyword VAR to the 
beginning of the parameter name, as in: 


Procedure Test (a: 
VAR b 


integer; 
integer); 


In this case, the variable a is passed by 


value, whereas the variable 6 is passed by 
reference. 
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Programmer’s Paradise Gives You Superb Selection, 
Personal Service and Unbeatable Prices! 


Welcome to Paradise. The microcomputer software source that caters to your programming needs. 


Discover the Many Advantages of Paradise... 


© Lowest price guaranteed 
© Latest versions 


LIST OURS 
386 SOFTWARE 
ADVANTAGE 386 C 895 805 
ADVANTAGE 386 PASCAL 895 805 
PHARLAP 3861ASM/LINK 495 419 
MICROPORT SYSTEM/386 799 699 
386 SCO XENIXSYS VCOMPLETE 1495 1195 
ARTIFICIAL INTELLIGENCE 
ARITY STANDARD PROLOG 95 79 
GOLDEN COMMON LISP 495 455 
MICROSOFT LISP 250 155 
PC SCHEME 95 85 
SMALLTALK V 99 85 
TURBO PROLOG 100 65 
TURBO PROLOG TOOLBOX 100 65 
ASSEMBLERS/LINKERS 
ADVANTAGE DISASSEMBLER 295 265 
ADVANTAGE LINK 395 359 
ASMLIB 149° «125 
EZ__ASM 70 65 
MICROSOFT MACRO ASSEMBLER 150 95 
PASM86 195 109 
PLINK86PLUS 495 275 
QUELO 68000 X ASM 545 509 
RELMS CROSS ASSEMBLERS CALL CALL 
UNIWARE CROSS ASSEMBLERS =CALL CALL 
VISIBLE COMPUTER 80286 100 89 
BASIC 
BETTER BASIC 199 129 
DB/LIB 99 89 
MACH 2 75 59 
MS QUICKBASIC 99 65 
TRUE BASIC 100 69 
TURBO BASIC 100 65 
DATABASE TOOLBOX 100 65 
EDITOR TOOLBOX 100 65 
TELECOM TOOLBOX 100 65 
XENIX/UNIX PRODUCTS 
SCO XENIX SYSTEM V-COMPLETE 1495 
SCO XENIX OPERATING SYSTEM 695 
MICROPORT SYSTEM V/AT. 549 
MICROPORT SOFTWARE DEV. SYS. 249 
OTHER SCO & MICROPORT 
ADVANTAGE C+ + 
BTRIEVE 
C-TERP 
INFORMIX ESQL/C 
INFORMIX 4GL 
INFORMIX SQL 
MICROSOFT LANGUAGES 
PANEL 
PANEL PLUS 
REAL TOOLS 
RM/COBOL 
RM/FORTRAN 
C++ 
ADVANTAGE C+ + 495 479 
PFORCE + + 395 209 
C COMPILERS 
C86PLUS 497 375 
DATALIGHT OPTIMUM-C. 139 105 
HIGH C 595 CALL 
LATTICE C SPECIAL PRICE 500 CALL 


Terms and Policies 

+ We honor MC, VISA, AMERICAN EXPRESS 

No surcharge on credit card or C.0.D. Prepayment by 
check. New York State residents add applicable sales 
tax. Shipping and handling $3.00 per item, sent UPS 
ground. Rush service available, prevailing rates. 

+ Programmer's Paradise will match any current nation- 


aly advertised price for the products listed in this ad. 
+ Prices and Policies subject to change without notice. 
+ New Extended Hours 9AM EST—7PM EST 
*Ask for details. Some manufacturers will not allow 
returns once disk seals are broken. 
Corporate Buyers — Call for special 
discounts and benefits! 


© Huge inventory, immediate shipment 
© Knowledgeable sales staff 


LIST OURS 
LET’S C W/CSD DEBUGGER 125 99 
MICROSOFT C 450 269 
QUICK C 99 65 
TURBO C 100 65 
C INTERPRETERS 
C-TERP 300 «229 
INSTANT C 500 379 
RUN/C 120 79 
RUN/C PROFESSIONAL 250 «155 
C LIBRARIES 
ASYNCH MANAGER 175 (135 
BASIC__C 175 «129 
C-FOOD SMORGASBORD 150 95 
W/SOURCE CODE 300 179 
C TOOLS PLUS 1750 «135 
C UTILITY LIBRARY 185 119 
C-XPERT 295 249 
ESSENTIAL COMMUNICATIONS 185 125 
COMMUNICATIONS PLUS 250 «189 
GREENLEAF FUNCTIONS 185 125 
GREENLEAF COMM LIBRARY 185 125 
GREENLEAF SAMPLER(TURBOC) 95 79 
MULTI-C 149° «135 
PFORCE 295 209 
RESIDENT C W/SOURCE 198 CALL 
TIMESLICER 295 265 
W/SOURCE CODE 1000 895 
TURBO C TOOLS 129 99 
COBOL 
FPLIB 149° «129 
MICRO FOCUS COBOL PRODUCTS CALL CALL 
MICROSOFT COBOL 700 «4439 
MICROSOFT SORT 195 129 
REALCICS 995 785 
REALIA COBOL 995 785 
W/REALMENU 1145 899 
RM/COBOL 950 759 
RM/COBOL-85 1250 999 
RM/SCREENS 395 315 
SCREENIO 400 CALL 
DEBUGGERS 
386 DEBUG 195 155 
ADVANCED TRACE-86 175 «119 
BREAKOUT 125 89 
C-SPRITE 175 «119 
PERISCOPE I 345 289 
PERISCOPE II 175 «139 
PERISCOPE III 8 MHZ 995 825 
PERISCOPE III 10 MHZ 1095 899 
PFIX 86 PLUS 395 209 
T DEBUG PLUS 60 49 
XVIEW86 60 49 
DISK/DOS/KEYBOARD UTILITIES 
BACK-IT 89 
BOOKMARK 100 79 
COMMAND PLUS 80 69 
INTELLIGENT BACKUP 150-135 
NORTON COMMANDER 75 55 
ADVANCED NORTON UTILITIES 150 89 
PDISK 145 89 
FILE MANAGEMENT 
BTRIEVE 245° 185 
XTRIEVE 245 «185 
REPORT OPTION 145 99 
BTRIEVE/N 595 455 


1-800-445-7899 
In NY: 914-332-4548 


Customer Service: 


914-332-0869 


International Orders: 


914-332-4548 
Telex: 510-601-7602 


© Special orders 


© 30-day money-back guarantee 


LIST 

XTRIEVE/N 595 
REPORT OPTION/N 345 
C-TREE 395 

R-TREE 295 

C-TREE/R-TREE BUNDLE 650 
DBC Ill 250 
DBC III PLUS 750 
INFORMIX PRODUCTS CALL 
PHACT MANAGER 249 
EDITORS 
BRIEF 195 

W/DBRIEF 275 
CVUE W/SOURCE CODE 250 
EDIX 195 
EMACS 295 
EPSILON 195 
KEDIT 125 
PC/EDT 250 
PC/VI 149 
Pi 195 
PMATEPRO. 195 
SPF/PC 195 
VEDIT PLUS 185 
XTC 99 
FORTRAN COMPILERS 
LAHEY FORTRAN 477 
LAHEY PERSONAL FORTRAN 77 95 
MICROSOFT FORTRAN 450 
RM/FORTRAN 595 
FORTRAN UTILITIES/LIBRARIES 
ACS TIME SERIES 495 
DOCUMENT’ER 129 
DIFF-E-Q 495 
FORTLIB 125 
FORTRAN ADDENDA 165 
GRAFLIB 175 
GRAFMATICS/PLOTMATICS 135 
MATHPAC 495 
NO LIMIT 129 
SSP/PC 350 
GRAPHICS 
ADVANTAGE GRAPHICS (C) 250 
ESSENTIAL GRAPHICS 250 
GSS GRAPHIC DEV. TOOLKIT 495 
HALO 300 
HALO (5 MICROSOFT LANG.) 595 
METAWINDOW PLUS 275 
TURBOWINDOW/C 95 
TURBO HALO (FOR TURBO C) 100 
LINT 
PC-LINT 139 
PRE-C 295 
MODULA-2 
FARBWARE MODULA-2 90 
LOGITECH MODULA-2 

APPRENTICE PACKAGE 99 

WIZARD PACKAGE 199 

MAGIC TOOLKIT 99 

WINDOW PACKAGE 49 
ROM PACKAGE AND CROSS 

RUNTIME DEBUGGER 299 
REPERTOIRE 89 
OPERATING SYSTEMS 
MICROPORT SYSTEM V/AT 

(COMPLETE) 549 
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LIST OURS 


SCO XENIX SYSTEM V 

(COMPLETE) 1295 995 
WENDIN-DOS 99 79 
OTHER MICROPORT, SCO, 

WENDIN PRODUCTS CALL CALL 
PASCAL COMPILERS 
MISCROSOFT PASCAL 300 «185 
PASCAL-2 350 329 
TURBO PASCAL NEWV. 4.0 100 65 
TURBO PASCAL DEV LIB NEW 395 259 
TURBO PASCAL ADD-ONS 
ALICE 95 69 
DOS/BIOS & MOUSE TOOLS 75 69 
FLASH-UP 89 79 
GSI PASCAL DEBUGGER 50 45 
METRABYTE DATA ACQ. TOOLS 100 89 


NEW PRODUCTS 


PI EDITOR — Lightning fast editor with all the fea- 
tures of today s most popular programmer's editors 
and more. Among PI’s 200+ commands and features 
are support for unlimited windows in any size, scroll- 
ing of windows simultaneously, background printing, 
and multiple file Suppor: PI also has extensive lan- 
jage support for Assembly, Basic, C, and Pascal. 
ingle stroke compile, and see your source and com- 
peice errors simultaneously. Much more, and PI 
enchmarks faster than our leading selling editors. 
List: $195 urs: $155 


RTC PLUS — Translator for converting either FOR- 
TRAN or RATFOR to C. No need to hand translate 
most of your code. RTC PLUS is perfect for translat- 
ing FORTRAN libraries, and any FORTRAN code 


where I/O is concentrated in a few routines. 
List: $450 Ours: $399 


JYACC APPLICATION MANAGER (JAM)—_ 
Powerful application generator for creating, testing 
and modifying forms and windows. A unique applica- 
tion shell is created to create, and then specify 
control flow between the screens and windows. 

List: $750 ~ Ours: $679 


THE AUTOMATED PROGRAMMER — Program- 
ming system for numerical computation that enables 
a computer to recognize and process mathematical, 
engineering, and scientific problem specs. Computa- 
tional formulas are translated into FORTRAN. The 
AUTOMATED PROGRAMMER offers a range of 
output choices from structured reports to pictures. 
Computational results may be embedded in complex 
2D text and graphic “IMAGE” formats. 


List: $995 Ours: $895 
SCREEN SCULPTOR 125 95 
SYSTEM BUILDER 150 129 
IMPEX 100 89 
REPORT BUILDER 130 «115 
TURBO. ASM 99 69 
TDEBUGPLUS 60 49 
TURBO ASYNCH PLUS 100 79 
TURBOEXTENDER 85 65 
TURBOHALO 129 99 
TURBOMAGIC 99 89 
TURBO MASTER 125 99 
TURBO NUMERICAL METHODS 100 65 
TURBO OPTIMIZER 75 65 
TURBO POWER TOOLS PLUS 100 79 
TURBOPOWER UTILITIES 95 79 
TURBOWINDOW/PASCAL 95 79 
SCREEN DISPLAY/WINDOWS 
C-SCAPE 279 CALL 
CURSES W/SOURCE CODE 250 169 
GREENLEAF DATA WINDOWS 225 «155 
W/SOURCE CODE 395 289 
JYACC FORMAKER 995 449 
JYACC JAM 750 669 
MICROSOFT WINDOWS 99 65 
MS WINDOWS DEVELOPMENT KIT 500 309 
PANEL 295 215 
PANEL PLUS 495 395 
PANEL/QC 129 95 
PANEL/TC 129 95 
QUICKSCREEN 195 175 
SCREEN ACE 195 169 
SCREENSTAR W/SOURCE 198 155 
VITAMIN C 225 165 
VC SCREEN 99 85 
WINDOWS FOR DATA 395 315 
VIEW MANAGER 275 +199 
ZVIEW 245 169 
ADDITIONAL LANGUAGES 
ACTOR 495 419 
HS/FORTH 395 359 
JANUS/ADA C PACK 95 89 
LATTICE RPG II COMPILER 750 629 
MASTER FORTH 125 «115 
PC/FORTH 150 109 
PERSONAL REXX 125 99 
THE WEINER SHELL 199 179 
ADDITIONAL PRODUCTS 
ADVANTAGE VCMS 379 329 
BASTOC 495 CALL 
CARBON COPY PLUS 195 179 
CODESIFTER 119 85 
DAN BRICKLIN’S DEMO PROGRAM —s75 59 
DB2C 299 CALL 
FLOW CHARTING IL 229° «205 
MAGIC PC 195 179 
NORTON GUIDES 100 65 
PFINISH 395 225 
POLYTRON PVCS CALL CALL 
SOURCE PRINT 95 7 
TP2C 249° «4199 
TREE DIAGRAMER 


VENTURA PUBLISHER 


A Division of Hudson Technologies, Inc. 


TM 


42 River Street, Tarrytown, NY 10591 


The difference is important. Variables 
passed by value and modified in a subrou- 
tine will retain their old values when the 
program returns to the calling procedure. 
Variables passed by reference and modified 
will “stay modified” in the calling routine. 

Which technique is better depends on 
the application. Passing by reference is 
more flexible since it allows the procedure 
to “return” multiple values by storing them 
into the parameters. Passing by value elimi- 
nates the chance for side effects in subrou- 
tines that change the values of these pa- 
rameters unexpectedly. However, there is a 


If performance means 
anything to you at all, 
always pass arrays 
of any size by 
reference by using 
the VAR prefix 

in front of their 
declarations in 
Procedure definitions. 


big problem with passing by value: How 
does one pass an array by value? 

To pass an array by reference, the pro- 
gram merely passes the address of the ar- 
ray, just as with a simple variable. The 
subroutine can use this address to access 
the entire array. No matter how large the 
array, the size of its address is always the 
same. To pass an array by value, however, 
the program must copy the entire array 
onto the program stack to be passed over 
to the subroutine. If the array is large, this 
wil' use up a large amount of stack space 
and a great deal of time will be spent copy- 
ing values around. For example, passing 
an array X declared ARRAY [1 .. 1000] 
OF INTEGER would involve passing 2000 
bytes (2 bytes per integer) to the 
subroutine. 

Of course, there is an easy way out of 
this problem: Pass simple variables by 
value, but pass arrays by reference, 
whether they are labeled VAR variables or 
not. This is a logical escape, and the man- 
ual for Turbo from Borland implies in sev- 
eral places that this is, in fact, the case 
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Listing 1. Experiment to determine how arrays are passed to procedures in 


Turbo Pascal 
Program Experiment; 
Type 
data = array [1..80] of integer; 
Var 
b, c : data; 
Procedure Change (b:data; var c:data); 
Begin 
b[{1] s= 11; 
e{1) := 12; 
writeln (‘inside the procedure Change'); 
writeln (‘b= ', b[1], ' c= ', c[1]); 
writeln; 
End; 
Begin 
b(1] := 1; 
efi] :=2; 
writeln (‘before the call'); 
writeln ('b= ', bf[l], ' e=', c[1)); 
writeln; 
Change (b, c); 
writeln (‘after the call’); 
writeln (‘b= ', b[1], ' c= ', c{i))? 
writeln; 
End. 


Listing 2. Output from program experiment 


before the call 
b=1 c=2 


inside the procedure Change 
b=11 c= 12 


after the call 
be=l c# 
before the / 
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with Turbo Pascal. It seemed so logical 
that I knowingly asserted this over and 
over again in this column and others. Un- 
fortunately, it ain’t so! 

Examine the program in Listing 1. No- 
tice how the arrays B and C are first ini- 
tialized. They are then passed to a proce- 
dure that sets them to some new value. 
Upon returning, the main program prints 
them out to screen to see whether the 
change “took” or not. Now examine the 
output from this program in Listing 2. 
Since C is a VAR variable and, therefore, 
passed by reference, we are not surprised 
that the value stays changed upon return- 
ing from the procedure. 

Now look at B. If it were also being 
passed by reference, we would expect it to 
stay changed, but it isn’t. A quick exami- 


nation of the .COM file reveals the awful 
truth: The entire array is copied onto the 
stack before the procedure is called. This 
apparently always happens in this situa- 
tion, regardless of the size of array B. I 
stand corrected. 

The moral to this story is: If perform- 
ance means anything to you at all, always 
pass arrays of any size by reference by us- 
ing the VAR prefix in front of their dec- 
larations in Procedure definitions. Not do- 
ing so will cost your program needless time 
and memory. § 


Stephen Randy Davis is a senior sys- 
tems programmer for a defense contrac- 
tor in Greenville, Texas, where he pro- 
grams various microprocessors. He is 
also working on his Masters in physics. 
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Blaise puts the 
Accent on C with 


C TOOLS PLUS/5.0 


Enhance your Microsoft C programming environment with 
C TOOLS PLUS/5.0™—a new, quintessential library of C 
ions. C TOOLS PLUS/5.0 from Blaise Computing Inc. puts a prime 
quickly building professional applications using the full power of 
C Version 5.0 and QuickC. Now you can concentrate on program 
by having full control over DOS, menus, interrupt service routines, 
resident programs, printer and keyboard control, and more! 


C TOOLS PLUS/5.0 prebuilt libraries are ready to use 
with either QuickC or the Microsoft C Version 5.0 com- 
mand line environment. Complete documented source 
code is included so that you can study and adapt it to your 
specific needs. Blaise Computing’s attention to detail, like 
the use of full function prototyping, cleanly organized 
header files, and a comprehensive, fully-indexed manual, ~~ ers Up 
makes C TOOLS PLUS/5.0 the choice forexperienced er 
developers as well as newcomers to C. | = BASCAE i 


Continuous refinement of Blaise Computing’s library E ‘festoutiieyrvesdudrvnit 
products has produced a collection of tools that are —: a <DOS file su 
unsurpassed for reliability, functionality and ease ofuse. ~~ ASYNCH MANAGER. 175,00 
j Built upon the widely acclaimed C TOOLS PLUS, a ~ ASYNCHMANAGER $75 Pt 
ECO . VO; buff XON, 
~ C TOOLS PLUS/5.0 includes such highly-developed Ea Soke ea One 
features as: '* XMODEM. For Ms: Pascal 


@INTERVENTION CODE i re 
— Schedule C functions at specified times, inter- 4 meee aa ‘ireacath Creat ihn 
orders, cursor memory. vals or with a “hot key’ NEW! © Ss swhich: can ‘invoke progtamS-and- 

AY Fuser input, formatted output. — Take full advantage of DOS, even from memory -« “input té thems run sat prouapr unaided 
—“printf” window-oriented output. NEW! resident programs. NEW! © = Create demonstration prograt 
@INTERRUPT SERVICE ROUTINES FAST DIRECT VIDEO ACCESS POE MARGE. 

— Capture DOS critical errors and keystrokes. — All monitors, even EGA 43-line mode. _ EXEC 
— Install hardware interrupt handlers. PRINTER CONTROL S 
@RESIDENT SOFTWARE SUPPORT — Access BIOS print functions. NEW! “tive. Chain ets. Mees 
— Install, detect and remove memory resident — Control the DOS PRINT utility. NEW! ‘ferent languages: specify’ 
programs. @UTILITIES AND MACROS ¥ “Jess, san eee rahe: 
@MENUS - sa ee of ae re structure. — ee ~ ; 
— Horizontal and pulldown. — Manipulate data types, far & near pointers. i 
a NEW! P — Access any memory areas with fast “peek” and t es a aan 
— Lotus-style support. NEW! “poke” macros. NEW! =H 


C TOOLS PLUS/5.0 supports the Microsoft C Version 5.0 and QuickC 
compilers, requires DOS 2.00 or later and is just $129.00. 


~ C ASYNCH MANAGER™ Version 2.0 IMPROVED! 
C ASYNCH MANAGER is a library of functions designed to help you 
incorporate asynchronous communication capabilities into your 
application programs. Version 2.0 has been rewritten especially for 
Microsoft C Version 5.0 and Borland’s Turbo C. Simultaneous 
buffered input and output to both COM ports at speeds up to 
9600 baud, XON/XOFF protocol, modem con- 


P Blaise sasensitiing Inc. has a full line of support residents 
products for both Pascal and C. Call today for your 4 ASS shippins 
free information packet. \ Name: 


\ Address: 


7 , 
BLAISE COMPUTING INC. 1 GisaorMC 


2560 Ninth Street, Suite 316 Berkeley, CA 94710 (415) 540-5441 Lee" 


Memory Addressing 


on the 


Intel 80386 


A Critical Look at the Newest 


hen Intel announced the 
8086, I recall reading that 
its segmentation scheme of 


address formation was so abstract that 
only systems programmers and compiler 
writers were likely to grasp it. Now the 
80386’s operating modes are causing simi- 
lar confusion. Recently it has been heard 
that, unlike the 286, the native mode of the 
386 is the protected mode. And from time 
to time, it is claimed that the 386 has any- 
where from two different operating modes 
on up. 

There seem to be two fundamental 
modes on the 386: real 386 and protected 
386. The real 386 mode is a superset of the 
8086, 186, and the real 286 modes of its 
predecessors, with some differences. If the 
differences are avoided, programs written 
for the older processors will be upwardly 
compatible, and the 386 can be seen as 
simply a faster processor with added in- 
structions and registers. 

As on the 286, the 386 comes up in real 
mode on reset. At the same time, the real 
386 mode cannot take advantage of all the 
386 features, such as 32-bit addressing, 
protection, paging, and hardware-assisted 
task switching. The only major difference 
between the 286 and 386 in this area is 
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that the 386 can return to real mode from 
protected mode without being reset. 

The 386’s protected mode is character- 
ized by 32-bit addresses and operands, as 
well as by the ability to provide multilevel 
rings of protection, virtual memory paging, 
and rapid task switching. The beauty of the 
386’s protected mode is that 32-bit opera- 
tion and paging can be enabled or disabled 
by default in any combination. That comes 
to four protected mode possibilities, plus 
real mode, for a total of five modes. 

A code segment that uses 32-bit ad- 
dresses by default is called a USE32 seg- 
ment in Intel terminology. When 32-bit 
addresses and operands are disabled by 
default, 16-bit addresses and operands are 
presumed. This code segment is called a 
USE16 segment, and it emulates the 286’s 
protected mode. Although the default ad- 
dress and operand length can only be set 
together as a pair, the use of 1-byte in- 
struction prefixes can override and reverse 
either of them on an individual instruction 
basis. That brings us up to nine modes of 
operation. 

A variation of the 286 mode is the vir- 
tual 8086 emulation mode (V86 mode). 
V86 mode looks just like real 386 mode 
except that V86 mode can be entered and 


Intel Processor Generation 


exited via task switching, and peacefully XG 


coexists with protection and paging. Intel 
supports V86 mode with a piece of soft- 
ware called the V86 monitor, which is in- 
tended to be bound to the system’s 386 
kernel. This monitor allows whole 8086 
operating systems to run as a V86 task, 
with an 8086 application as a V86 subtask. 
Through special software hooks into the 
CPU, the monitor intercepts I/O and in- 
terrupts, but only engages the task gate 
overhead of calling the coresident 32-bit 
protected mode operating system when re- 
quired. The V86 mode, like the real 386 
mode, forms effective addresses in the 
same way as the 8086. With the V86 mode 
we now have ten modes of operation. 

Effective address formation is still at 
the heart of the Intel scheme of things. On 
the 8086, effective addresses are formed 
by taking the value in a segment register, 
multiplying it by 16 (shifting it left 4 bits), 
and then adding the result to a pointer reg- 
ister. The segment register can be consid- 
ered a pointer itself, albeit a pointer to 
memory on a 16-byte boundary (often 
called a paragraph). 

The 286 and 386 are more unusual by an 
order of magnitude. In the protected mode, 
the segment register is no longer a pointer 
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to real user code or data. Instead it contains 
something called a “selector.” Within the 
16-bit selector, 13 bits constitute a record 
number for access to a database called a 
“descriptor table.” The descriptor table is 
somewhat different from the databases fa- 
miliar to most programmers. The records 
are all 8 bytes long, but they have a number 
of different formats. The code segment reg- 
ister selects an “executable segment de- 
scriptor,” while other segment registers 
usually select “data segment descriptors,” 
which may be of the “expand down” vari- 
ety for optimal stack usage. 
In addition, there are five types of “gate 
descriptors.” Gate descriptors are special 
descriptors that, instead of pointing di- 


rectly to code segments, point to other exe- 
cutable descriptors that, in turn, point to 
code segments. Gate descriptors are gen- 
erally used to provide regulated, indirect 
access to processes of a higher privilege 
level, or to other tasks. A call gate is used 
in protected mode, for example, by far 
JMP and CALL instructions, which in real 
mode need a segment as part of the oper- 
and. The other gates are trap, interrupt, 
and task gates, and a collection of system 
segment gates. 


In protected mode, the descriptor tables 
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are where the action is. Thus in protected 
mode, the 386 segment registers select 
records from a descriptor table. A linear 
address is formed by fetching a 32-bit seg- 
ment base address from the appropriate 
descriptor, and adding it to the user’s 
pointer register. The descriptor also sets 
the segment size (from | byte to 4 giga- 
bytes) and contains privilege information. 
Tests are performed to see if the intended 
memory reference will be permitted. The 
days of reading or writing to memory not 
allocated to you for that purpose will be 
gone. That’s protection. 

Once the linear address is in hand, the 
on-chip paging hardware translates further 
to a physical address. This step is optional. 
If paging is implemented, the linear ad- 
dress is broken into three parts: a 12-bit 
physical offset, a 10-bit page table record, 
and a 10-bit page directory record. Two ta- 
bles are referenced: a page directory table 
and a page table. The page directory record 
is fetched and points to one of a number of 
page tables. The page table record is then 
fetched and contains a 20-bit page number 
as well as flags indicating whether the page 
has been written to (dirty bit) and is 
present in memory. Pages are 4K long. The 
final physical address is obtained by con- 


catenating the page number (20-bits) to 
the physical offset (12-bits from the linear 
address). Pages can be swapped from disk 
or slower memory. Figures | and 2 illus- 
trate how translation works. 

Address translation is the key to physi- 
cal hardware independence. It is crucial in 
a multitasking environment. All segment, 
interrupt, and I/O requests undergo de- 
scriptor and/or page translation. The op- 
erating system remaps by simply patching 
a translation table. Therefore, concur- 
rently running programs will never know it 
when the video RAM is switched out from 
under them. 

With all this translation and checking 
going on, the 64K question is: What hap- 
pens to processor performance in protected 
mode? Considering that the 386 does no 
on-chip instruction or data caching in the 
ordinary sense, its performance is remark- 
able. The buffering it does do is in connec- 
tion with translation tables. The segment 
registers are unusual in that they are actu- 
ally wider than they appear. Only a 16-bit 
portion is visible; a hidden portion acts as a 
descriptor buffer. Subsequent address cal- 
culations and privilege checks consume no 
additional cycles. Page table records are 
also retained in a 32-register cache called a 
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“translation lookaside buffer.” But there’s 
no getting around it, instructions that ac- 
cess descriptor or page tables for the first 
time are going to take longer. 

Figure 3 lists comparative cycle times 
for instructions that force access to a de- 
scriptor table. They are all segment- 
changing, I/O, or interrupt instructions. 
When comparing 286 and 386 instructions 
that purge the prefetch queue, note that 
the 386 fetches operands and addresses in 
one cycle, whether these are 8-, 16-, or 32- 
bits long. The 286 always fetches 1 byte 
per cycle. 

Any other gotchas? I’ve already alluded 
to a few. 8086 or 286 code that uses the 
LOCK prefix may trigger an undefined 


Address translation 
is the key to 
physical hardware 
independence. 

It is crucial ina 
multitasking 
environment. 


opcode exception (INT 6) if used with 
other than a limited set of instructions. 
Noticeably absent from this acceptable set 
are the string instructions. And even when 
it is effective, the memory protected from 
coprocessor interference is now limited to 
the memory area defined by the destina- 
tion operand of the instruction so prefixed, 
instead of to the entire physical address 
space. This need only be of concern to de- 
signers of multiprocessor systems. 

In V86 mode, page translation seems to 
be required if multiple V86 tasks are de- 
sired since descriptor translation is by- 
passed. The new instructions are somewhat 
of a problem also. Some of them overlap 
with the NEC V20 unique instructions. 

All those protected mode 286 operating 
systems already out there will probably 
need some adjustment if they’re to run asa 
task‘under a full-featured 386 kernel. The 
task state segment (TSS) is a structure in 
memory in which the processor saves its 
registers when multitasking. TSSs are very 
different on the 286 and 386—after all, 


20 


Figure 1. In protected mode, a linear address is formed by fetching a 
32-bit segment base address from the appropriate descriptor and 
adding it to the user's pointer register. 
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Figure 2. Once the linear address is formed, the on-chip paging 
hardware translates further to a physical address. 
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the 386 has more registers. If the 386 ker- 


Figure 3. Here is a list of comparative cycle times for instructions nel were prevented from changing regis- 


that force access to a descriptor table. tere “that the: 286 ‘suboperating cystem 
doesn’t save and restore (for example, 


Page Directory Base Register), it would be 


necked Ph hl little more than a 286 system itself. The 
more practical approach would be to use 
MOV seg,r16 386 TSSs throughout. 

MOV seg,mem16 What enhancements would I like to see 
on the 486? Tops on my list would be on- 
: chip data, code, and stack caches, as well 
CALL imm32 as more data registers. And while we’re at 
noes Megs it, what about adding a Z80-styled alter- 
JMP imm32 nate register array? There’s no reason why 
JMP mem32 there can’t be a megabyte or two on-chip 

IN acc,imm for registers and caches. 
Regardless of how many modes you 
IN acc,DX think the 386 has, one thing is clear. Intel 


is committed to upward compatibility 
throughout the 8086 family. With that, 
and its top-notch performance, the 386 
has an excellent chance of achieving what 
has so far eluded the 8086 family: parlay- 
ing its microcomputer dominance into a 
stonger position in the multiuser 
marketplace. § 


Howard Vigorita is an attorney on the 
staff of the United States District Court in 
New York and serves as vice president of 
the New York Amateur Computer Club. 


What you see is what you get .. . and send! | 
Transfer Protocol: Modem?/CRC Packet Size: 128 = Files: i 
FA 


Remaining |Consec| File 


ae sep tat at 


Errors! 
Status: Transfer in progress 


—(MEX File Transfer 
Sending: DANVFILE. AQC 


Announcing Version 1.6 of MEX, the communications software with a view from the top. Regardless of your level of 
sophistication, MEX can put you on top of the data transfer game and keep you there. For the executive on the go, our new 
pull-down transfer screen and easy-to-use menus reduce the complexities of modem communications to a few keystrokes. 
For the advanced user, MEX’s greatly enhanced script processor offers a complete programming language for development 
of highly secure custom applications. If communication is money in your business, MEX may be the best investment you 
make this vear 


Two options available: 
MEX-PC is the most complete modem software you can buy. Allows you to switch 
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MEX-PAC — All the features of MEX-PC, plus 


between menu-driven and command-driven communications at will. Makes full use ()A remote module that allows you to run your office computer from home, and vice 
of Hayes AT command set, with overlays available for most other modems. Features versa; and 
include: complete script processor programming language; user-definable keystrings; ()Terminal emulation that lets your PC masquerade as a DEC VT52/100 or Televideo 
auto-dial and auto-baud-set phone libraries; all popular protocols, including 925 terminal for on-line communication with mainframes. $99.95* 
MODEM-7 batch transfers $59.95* 

XMODEM CRC/XMODEM CHECKSUM/KERMIT/COMPUSERVE A/128 or 1K BLOCKS Versions available for IBM-PC and compatibles, Tandy 2000 and most CP/M machines. 
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In Wisconsin, 1-414-563-4013 
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Hardware Review 


The Micronics 


80386 


System Board 


The Compaq 386 was the first 80386 MS- 
DOS-compatible computer to receive wide 
exposure, and the system still serves as the 
industry standard. Recently, I had the 
opportunity to acquire a system that is ba- 
sically a Compaq 386 clone, an AT-form- 
factor system board designed and manu- 
factured in the United States by Micronics 
Computers (formerly known 
as Four Star). Micronics ini- 
tially configured complete 
systems, but now has gone 
into full-time system board 
production. The system re- 
viewed here was configured 
by Dyna (a clone manufac- 
turer) and is sold by Servu, al- 
though the Micronics board is 
available from other sources 
as well. 

The system received for re- 
view consisted of the 
Micronics board with 1 
Mbyte of static column 
RAM, a Western Digital 
floppy /hard-disk controller, a 
Seagate ST4038 hard disk, 
360K and 1.2-Mbyte Toshiba 
floppy disk drives, and a 
Quimax AT-style keyboard. I 
added a Tseng EVA/480 dis- 
play card, an additional 
megabyte of RAM, and an 
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I/O board containing a parallel and two se- 
rial ports. Servu will supply the system 
board with | Mbyte of RAM for $1,595, 
and a complete monochrome system is 
available for approximately $3,400. 

As in the Compaq, there is a single, 32- 
bit expansion connector that can accept a 
memory expansion board. The standard 


The 80386 System Board Recently Introduced by Micronics 
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configuration has 1 Mbyte of static col- 
umn chips soldered in, with sockets for an- 
other 1 Mbyte. An optional piggyback 
board is available for $335 that allows ex- 
pansion to 4 Mbytes using 256K chips. 
The system can accommodate up to 10 
Mbyte of RAM in its full configuration. 
Of course, the similarity to the Compaq 
cannot extend to the use of 
Compaq’s BIOS. Micronics 
uses both the Phoenix and 
Award chips. 

The system is supplied 
with several utilities on disk, 
including a SETUP program 
to set the clock/calendar, 
configuring the drives, and so 
on. Also supplied is a SET- 
SPEED utility that allows the 
operator to slow the system 
speed in several steps to that 
of a 4.77 MHz PC. Since the 
seven AT-style expansion 
slots run at 8 MHz, I had lit- 
tle reason to slow things 
down. The only time I did so 
was when I used my Irwin 
tape drive for backups. (This 
backup device is designed for 
the external floppy disk con- 
nector on a PC or XT, but Ir- 
win supplies a board that 
plugs into an AT and allows 
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Make $500/hr. 


Now develop DBMS applications 10 times faster for 


only $199 with MAGIC PC — or your money back! 


Database programmers, why waste your a 
time hacking out code? : 
Imagine how much faster and more profit- 
able you'd be if you could whip up power- 
ful database applications without the 
time-consuming coding pains... 
Introducing Magic PC from Aker, your pro- 
fessional dream come true. It's not 
another line-by-line syntax treadmill like 
any DBMS or 4GL. 

Finally you can program as quickly as you 
design, while you delegate all the mun- 
dane and redundant coding tasks to 
Magic PC. 


Program 10 times faster + 


Develop rate 


relational 
PARADOX 
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database 
applications 
10 times fas- 
ter usinga 
visual 
design- 
driven inter- 
face. Instead of writing mountains of “how 
to” procedural code, you quickly place your 
program design specs in Execution Tables 
and Magic PC's engine executes them auto- 
matically. Don't lose any more time editing 
and debugging programs by hand. 


ee | | 


Incredible Zoom power 
Magic PC's 
pheno- 
menal 
Zoom 
power mag- 
ically co- 
executes 
related 
programs 
through nested Zoom windows smoothly 
with auto data scrolling in all directions. 
While Zooming, query and transfer data 
across windows or even Zoom deeper. 


No more maintenance! 


Change your programs on the fly without 
any manual maintenance responsibility. 
Magic PC automatically updates your 
changes online since all the data describing 
your design (data dictionary, programs and 
menus) make up a single file, self- 
maintaining Integrated Library. 


import/export, etc.) with full color and gra- 
phics. You no longer fall between the cracks 
dealing with separate and inconsistent 
programming utilities. 

Free LAN features 
Develop multi-user applications for 
local area networks with Magic PC's 
automatic support for file and 
record locking security. 


Quick prototyping 
Prototype a complete working application 
in just hours and get immediate customer 
feedback to finalize the design. It's a true 
time-saver. 

Stand-alone runtime 
Distribute your applications and protect 
your design with a low cost runtime engine. 
It has the friendliest end-user visual inter- 
face you've ever seen with built-in, menu- 
driven and syntax-free data retrieval power. 


Jeff Duntemann, PC Tech Journal: 


“Magic PC is probably the best integrated 
database application generator that we 
have seen...very smooth system, and 
smoothness comes at a premium these 
days." Also recommended by PC Magazine, 
PC World, PC Week, Computer Language, 
Data Based Advisor and many more around 


the world. 
Try it for $19% 


If you develop database applications fora 
living, you can't afford not to try Magic PC for 
yourself right now. For $19.95 you'll get the 
Magic PC Tutorial software and documenta- 
tion for hands-on evaluation, complete with 
a step-by-step guide to develop an Order 
Entry sample application in just a few 


hours. 
Magic PC 360K $199 


No kidding! For a limited time only, save 
almost $500 off the $695 list price, and get 
the complete unprotected Magic PC soft- 
ware for only $199 at our special introduc- 
tory non-resale price. 


Money back guarantee 


Even at $199 you can't go wrong with our no- 
risk guarantee: keep it only if it makes 

magic for you, or we'll buy it back 

within 30 days less $19.95 

restocking fee. 


System Requirements: 
IBM PC, XT, AT, PS/2 
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The \Md/ Database Language 


THE CURE 


FOR COMMON CODE 


A® you getting the recommended monthly 
allowance of C, Assembly, Forth, Pascal, 
BASIC or Modula-2? Subscribe to Dr. Dobb’s 
Journal of Software Tools and you won’t catch 
any nasty bugs again! 
Each month the Doctor brings you aid for 
ailing algorithms and the cure for common 
code. For the latest developments in 
software design and pages of code that will 
make you a more productive programmer, 
take the Dr. Dobb’s prescription. 
For more than a decade, the programming 
elite have known Dr. Dobb’s Journal to be 
the foremost source of software tools. 
, Subscribe now and get your monthly dose 
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Figure 1. MIPS benchmark tests results 


BENCHMARK 
PERFORMANCE IBM/AT COMPAQ’ ACTUAL 
RELATIVE TO => 8 MHz 386 MIPS 
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Integer instructions 
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Register to register 
Register to memory 


Overall performance 


Figure 2. PC Magazine \aboratory benchmark series 


SPEED INDEX SPEED INDEX 
TIME IN RELATIVETO RELATIVE TO 


SECONDS 4.77 MHz PC 8 MHz AT 


. 128K NOP loop: 2.09 4.80 
. Do-Nothing loop: 1.86 5.30 
. Integer add loop: 0.99 10.00 
. Integer mulitply loop: 0.61 16.40 
. String sort and move: 1.32 8.00 
. Prime number sieve: 1.82 8.50 


Bench21—Version 1.31: Processor speed benchmark test 
SPEED INDEX SPEED INDEX 


TIME IN RELATIVETO RELATIVE TO 
SECONDS 4.77 MHz PC 8 MHz AT 


8086/8088 instruction set 4.29 7.50 


Bench28-—Version 1.01: Processor speed instruction mix test 


SPEED INDEX SPEED INDEX 
TIME IN RELATIVETO RELATIVE TO 
SECONDS 4.77 MHz PC 8 MHz AT 


Floating point (no 80287): 22.30 7.00 1.60 
Floating point (with 80287): 3.35 1.50 0.90 


Bench29-Version 1.01: Floating point and math coprocessor test 
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the drive to be used through its connector. 
When using this combination, it became 
necessary to slow down the clock to pre- 
vent BIOS parity error messages. ) 

Another useful utility is RELOCATE, 
which allows both BIOS and EGA BIOS 
code to be moved to high-speed memory. 
The memory map is identical to the Com- 
paq in that the upper 384K of the first 
megabyte of RAM is dedicated to system 
use. The RELOCATE utility moves the 
code to this area, allowing full speed access. 
The speed enhancement is significant. 

Lastly, Micronics includes an expanded 
memory driver (Lotus/Intel/Microsoft 
standard), functionally similar to 
Compaq’s CEMM.SYS. This driver allows 
programs such as Lotus 1-2-3 to take ad- 
vantage of the extra memory in order to 
expand the maximum size of a spread- 
sheet, to run the FLASH expanded mem- 
ory disk cache program, and to perform 
other functions. 

The system board has a socket for an 
80287 numeric processor that can run at 4 
MHz, 8 MHz, or 10 MHz, depending on 
switch positions (although in the last case, 
actual crystal replacement is necessary). I 
removed the 80287 from my 80286 system 
and had no trouble installing it in the new 
board. It is unfortunate that Micronics did 
not include. a socket for the 80387, but 
they have just informed me that a piggy- 
back board will shortly be released that 
plugs into the 386 socket. The 386 and a 
387 may in turn populate the piggyback. 
It is also rumored that Intel may release 
an 80387 in a package pin-compatible 
with the 80287 to complement the (also 
rumored) 80386 in a 80286 pin-compati- 
ble package. 

The balance of the hardware in the 
tested configuration is familiar AT-com- 
patible technology. The disk drive is proba- 
bly a little slower than the ideal for a speed 
demon such as this, but virtually any ST- 
506-compatible drive should work. Some 
video boards might have problems with the 
system because of its speed, but the Tseng 
used for testing operates flawlessly. 

I do have one serious complaint—the de- 
signers neglected to include a hardware re- 
set button on the system. Therefore, in or- 
der to do a hard reset (when Ctrl-Alt-Del 
fails), it is necessary to completely power- 
down the system, which is not only annoy- 
ing but potentially damaging to the equip- 
ment. (Interestingly, IBM also omits the 
reset button on its PC and PS/2 systems.) 


Compatibility 
The best way to give a new system a thor- 
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Minimize 
Turbo 
Pascal 
compile 
time. 


Dramatically reduce 
debugging time. 


Tmark allows Turbo Pascal 
to continue compiling 
without returning to line 1. 


Tmark is a utility that fixes an 
annoying limitation of Turbo Pascal. 
Normally, every time Turbo finds an 
error while compiling, it must start 
compiling again from the very begin- 
ning. Tmark changes that. It allows 
Turbo to resume compiling from 
where you fixed the error, not back at 
line 1. 

Tmark runs Turbo Pascal as a 
child process. This allows Tmark to 
monitor Turbo as it compiles your 
program. When Tmark detects that 
Turbo is about to issue an error mes- 
sage, it saves, on disk, an image of the 
memory and registers used by Turbo 
Pascal up to that point. Once you have 
fixed the error, Tmark will restore 
Turbo to its state before the error was 
found. Turbo will then resume compil- 
ing—from the fix. 

Tmark will also save up to 7 
images at designated lines in a pro- 
gram. When Turbo encounters a line 
which begins with {TMARK}, Tmark 
will save an image. You can resume 
compilation at any of these lines. 

Don’t lose another minute of 
compiling time, order Tmark now! 


¢ Not memory resident 

© Does not take over any software 
interrupts. If Turbo Pascal runs on 
your system, so will Tmark. 

¢ Not copy protected 


Pmark. 


Only $80 


Visa/MC accepted. Add $2 for shipping 
in U.S., $5 overseas 


Tangent Designs, Inc. 


P. O. Box 896 

Lake Forest, IL 60045 
(800) 356-2750 Outside Illinois 
(312) 295-0030 


Turbo Pascal is a registered trademark of Borland 
International. Supports Turbo versions 3.01 and 
above, with 8087 or BCD. 


ough workout is to use it every day as one’s 
main system. In fact, I have been running 
a variety of software on this machine and 
have experienced no trouble at all. Modem 
programs such as Qmodem, Pro-Yam, 
PC-VCO and Procomm, work fine. Word 
processors (WordStar 4 and Microsoft 
Word), spreadsheets (SuperCalc 4 and 
Lotus 1-2-3), and utilities such as Norton 
and Media Master, also operate flaw- 
lessly. And, of course, all the DOS 3.2 util- 
ities perform as they would on an AT, only 
much faster. In addition, there are no 
hardware or software problems running a 
parallel Epson FX-80 printer nor a 
Hewlett-Packard serial Laserjet printer. 


80386 Software 

In addition to increased speed, the best 
reason to purchase an 80386 system is to 
run 80386 software. I had the opportunity 
to test several such packages. Quarter- 
deck, the authors of DESQview, supply an 
expanded memory simulator similar in 
concept to that supplied by Micronics and 
Compaq. However, QEMM.SYS goes 
them one better by implementing a subset 
of the AST/Quadram/Ashton-Tate ex- 
panded memory specification. This allows 
DESQview 1.3 to use all the available 
80386 memory for running concurrent 
applications. I have always been a fan of 
DESQview. Its ease of use (there is little 
need to read the manual) and multitasking 
capabilities are now coupled with the abil- 
ity to run multiple large applications. 
DESQview and QEMM.SYS ran flaw- 
lessly, permitting, for example, xmodem 
protocol file transfers from GEnie while 
simultaneously running utilities in a 256K 
DOS window. 

Another recent development in the 
80386 software scene is Digital Research’s 
Concurrent DOS 386. I will leave a discus- 
sion of the details of CDOS 386 for the 
review in this issue and just say that I have 
been running it for several weeks on the 
Micronics System straight out of the box 
with no problems whatsoever. (See page 
28 for a review of Concurrent DOS 386.) 

Lastly, I had the opportunity to beta test 
a newcomer to the operating system scene, 
PC-MOS/386 from The Software Link of 
Atlanta, Ga. PC-MOS, like CDOS 386, is a 
stand-alone operating system designed to 
replace PC-DOS. It supplies all the existing 
functionality of the Microsoft operating 
system while enhancing it with features tai- 
lored to the increased speed and memory 
addressing power of the 80386. It was de- 
veloped on a Compaq 386 but runs satisfac- 
torily on the Micronics system. One small 


glitch is that the BIOS reports a memory 
error on boot-up, but there is no apparent 
ill effect, and PC-MOS behaves properly. It 
is unclear at this point if there is a hard- 
ware problem, or a BIOS or software in- 
compatibility of some sort. 


Benchmarks 

No review of an 80386 computer is com- 
plete without a suite of tests benchmark- 
ing speed. The Norton Sysinfo (SI) utility 
Version 3.10 reports that the system is 
equivalent to an 18.7 IBM PC. I under- 
stand that this is identical to results on the 
Compaq 386. MIPS, a popular benchmark 
program from Chips & Technologies, Inc. 
(available in the PC/Blue public domain 
software library), produced the timings 
shown in Figure 1. 

PC Magazine has developed an exhaus- 
tive series of benchmarks and has released 
them into the public domain. I ran several 
of the CPU/memory tests from Version 4 
of the series as shown in Figure 2. 

The benchmark series is apparently not 
set up to correctly identify and deal with 
an 80386 microprocessor, for the last 
benchmark was littered with garbage 
characters in the locations where “80386” 
and “80287” should have appeared. The 
results, however, seem to make sense in 
light of the 4 MHz operation of the nu- 
meric processor as opposed to 5.33 MHz 
on an 8 MHZ AT. 


Conclusion 

I am very pleased with the Micronics 
80386 system. It offers the blazing speed 
of the new generation of compatibles at a 
very affordable price. The manufacturer 
does not appear to have cut corners in de- 
sign and fabrication of the computer. I am 
eagerly looking forward to many happy 
hours investigating the new 80386 soft- 
ware that is just now starting to appear on 


the market. § 

Charles H. Strom is Director of Lab- 
oratories and Associate Director of Tech- 
nical Services in the Department of 
Chemistry at New York University. 


Product Information 
Micronics Computers Inc. 
110 Pioneer Way, Bldg. D 
Mountain View CA 94041 
(415) 962-0102 

SERVU 

3008 Oakbridge Dr. 

San Jose, CA 95121 

(408) 274-8112 
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*TM OF DIGITAL RESEARCH INC. (CALIF.) 


ALL SALES ARE MADE SUBJECT TO THE TERMS OF OUR 90 DAY LIMITED WARRANTY. A COPY OF THIS WARRANTY IS AVAILABLE FREE, ON REQUEST. 


DIGITAL RESEARCH COMPUTERS 
(214) 225-2309 


S100 EPROM PROGRAMMER 

OUR NEWEST DESIGN, FOR FAST EFFICIENT PROGRAMMING OF THE 
MOST POPULAR EPROM’S ON YOUR S100 MACHINE. COMES WITH 
MENU DRIVEN SOFTWARE THAT RUNS UNDER CP/M 2.2 (8 INCH). PC 
BOARD SET CONSISTS OF ($100) MAIN LOGIC BOARD REMOTE 
PROGRAMMING CARD AND SIX PERSONALITY MINI BOARDS FOR 
2716, 2532, 2732, 2732A, 2764, AND 27128. SOLD AS BARE PC BOARD 
SET ONLY WITH FULL DOC. SOFTWARE FEATURES “FAST” 
PROGRAMMING ALGORITHM. FOR Z80 BASED SYSTEMS. 


PC BOARD SET, FULL 
DOCUMENTATION, 8 IN. 
DISKETTE WITH SOFTWARE. 


128K S100 STATIC RAM/EPROM BOARD 
JUST OUT! USES POPULAR 8K X 8 STATIC RAMS (6264) OR 2764 
EPROMS. FOR 8 OR 16 BIT DATA TRANSFERS! IEEE 696 STANDARD. 
LOW POWER. KITS ARE FULLY SOCKETED. FULL DOC AND 
SCHEMATICS INCLUDED. 24 BIT ADDRESSING. 

$439% 


$ 95 $ 00 
NEW! oe “te 128 EPROM KIT 


BARE PC BOARD 128K RAM KIT 


256K S-100 SOLID STATE DISK SIMULATOR! 

WE CALL THIS BOARD THE “LIGHT-SPEED-100” BECAUSE IT OFFERS 

AN ASTOUNDING INCREASE IN YOUR COMPUTER'S PERFORMANCE 

WHEN COMPARED TO A MECHANICAL FLOPPY DISK DRIVE. 
FEATURES: 


PRICE CU * 256K on board, using +5V 64K 


. * Uses new Intel 8203-1 LSI Memory 
ey | if Controller. 
re] iS : * Requires only 4 Dip Switch 
Selectable I/O Ports. 
a, * Runs on 8080 or Z80 S100 machines. 
, * Up to 8 LS-100 boards can be run 
together for 2 Meg. of On Line Solid 
State Disk Storage. 

* Provisions for Battery back-up. 

* Software to mate the LS-100 to your 
CP/M* 2.2 DOS is supplied. 

* The LS-100 provides an increase in 
speed of up to 7 to 10 times on Disk 
Intensive Software. 

* Compare our price! You could pay 
up to 3 times as much for similar 
boards. 


BLANK PCB 
(WITH CP/M®* 2.2 
PATCHES AND INSTALL 
PROGRAM ON DISKETTE) 
$2495 


(8203-1 INTEL $29.95) 


$2495 


#LS-100 


ZRT-80 CRT TERMINAL BOARD! 


A LOW COST Z-80 BASED SINGLE BOARD THAT ONLY NEEDS AN 

ASCII KEYBOARD, POWER SUPPLY, AND VIDEO MONITOR TOMAKEA 

COMPLETE CRT TERMINAL. USE AS A COMPUTER CONSOLE, OR 

WITH A MODEM FOR USE WITH ANY OF THE PHONE-LINE COMPUTER 

SERVICES. 

FEATURES: 

* Uses a Z80A and 6845 CRT 
Controller for powerful video 
capabilities. 

RS232 at 16 BAUD Rates from 75 
to 19,200. 

24 x 80 standard format (60 Hz). 
Optional formats from 24 x 80 

(50 Hz) to 64 lines x 96 characters 
(60 Hz). 

Higher density formats require up to 
3 additional 2K x 8 6116 RAMS. 
Uses N.S. INS 8250 BAUD Rate Gen. 
and USART combo IC 

3 Terminal Emulation Modes which 
are Dip Switch selectable. These 
include the LSI-ADM3A, the Heath 
H-19, and the Beehive. 

Composite or Split Video 

Any polarity of video or sync 
Inverse Video Capability 

Small Size: 6.5 x 9 inches. 

Upper & lower case with descenders 

7 x 9 Character Matrix 

Requires Par. ASCII keyboard 


FOR 8 IN. SOURCE DISK 


OR PC-XT FORMAT 5% IN. 
ADD $10 


Digital Research Computers 


P.O. BOX 381450 » DUNCANVILLE, TX 75138 + (214) 225-2309 


ADD 
#ZRT-80 $50 


(COMPLETE KIT, 2K VIDEO RAM) 


OUR BEST 
SELLER! 


CLOSE OUT! BLANK PCB ONLY: 


LOW POWER! 
150 NS ADD $10 


BLANK PC BOARD 
WITH DOCUMENTATION 
$49.95 


SUPPORT ICs + CAPS 
$17.50 


FULL SOCKET SET 
$14.50 
FULLY SUPPORTS THE 
NEW !EEE 696 $100 
STANDARD 
(AS PROPOSED) 


| ASSEMBLED ae 
TESTED ADD $50 

1 MEG. S-100 SOLID STATE DISK SIMULATOR! 
WE CALL THIS BOARD THE “LIGHT-SPEED-100” BECAUSE IT OFFERS 


AN ASTOUNDING INCREASE IN YOUR COMPUTER’S PERFORMANCE 
WHEN COMPARED TO A MECHANICAL FLOPPY DISK DRIVE. 


LS 4 00 Il FEATURES: 


FeaTurES: PRICE CUT! 


Uses new 2K x 8 (TMM 2016 or HM 6116) RAMs. 
Fully supports IEEE 696 24 BIT Extended 
Addressing. 

64K draws only approximately 500 MA. 

200 NS RAMs are standard. (TOSHIBA makes 
TMM 2016s as fast as 100 NS. FOR YOUR HIGH 
SPEED APPLICATIONS.) 

SUPPORTS PHANTOM (BOTH LOWER 32K 
AND ENTIRE BOARD). 

2716 EPROMs may be installed in any of top 48K. 
Any of the top 8K (E000 H AND ABOVE) may 
be disabled to provide windows to eliminate 
any possible conflicts with your system monitor, 
disk controller, etc. 

Perfect for small systems since BOTH RAM and 
EPROM may co-exist on the same board. 
BOARD may be partially populated as 56K. 


* 1 Meg. on board, using +5V 256K 
DRAMS. (With Parity) 

* Uses new Intel 8203-1 LSI Memory 
Controller. 

* Requires only 4 Dip Switch 
Selectable 1/O Ports. 

=; * Runs on 8080 or Z80 S100 machines. 
“tq * Up to 4 LS-100 boards can be run 
together for 4 Megs. of On Line 
Solid State Disk Storage. 
| * Provisions for Battery back-up. 
i f< * Software to mate the LS-100 to your 
| CP/M* 2.2 DOS is supplied. 

* The LS-100 provides an increase in 
speed of up to 7 to 10 times on Disk 
Intensive Software. 

* Compare our price! You could pay 
up to 3 times as much for similar 


S95 00 


(ADD $50 FOR A&T) 
#LS-100 11 (FULL 1 M.B. KIT) 
1 MEGA BYTE! 


THE NEW 65/9028 VT 
ANSI VIDEO TERMINAL BOARD! 


* FROM LINGER ENTERPRISES « 
A second generation, low cost, high performance, mini sized, single 
board for making your own RS232 Video Terminal. This highly versatile 
board can be used as a stand alone video terminal, or without a 
keyboard, as a video console. VT100, VT52 Compatible. 


FEATURES: MICRO SIZE! 

* Uses the new CRT9128 Video Controller 
driven by a 6502A CPU 

* On-Screen Non-Volatile Configuration 

* 10 Terminal Modes: ANSI, H19, ADM-5, 
WYSE 50, TVI-920, KT-7, HAZ-1500, ADDS 
60, QUME-101, and Datapoint 8200 

* Supports IBM PC/XT, and Parallel ASCII 
Keyboards 

* Supports standard 15.75 kHz (Horiz.) 

* Composite or Split Video (50/60 Hz) 

* 25 X 80 Format with Non-Scrolling User Row 

* Jump or Smooth Scroll 

* RS-232 at 16 Baud Rates from 50 to 19,200 

* On Board Printer Port 

* Wide and Thin Line Graphics 

* Normal and Reverse Screen Attributes 

* Cumulative Character Attributes: De-Inten, 
Reverse, Underline and Blank 

* 10 Programmable Function Keys and 
Answerback message 

* 5 X 8 Character Matrix or 7 X 9 for IBM 
Monitors 

* Mini Size: 6.5 X 5 inches 

* Low Power: 5VDC @ .7A, + 12VDC @ 20mA. 


BLANK PCB 
(WITH CP/M* 2.2 
PATCHES AND INSTALL 
PROGRAM ON DISKETTE) 
$5995 


(8203 1 INTEL $29.95) 


H bee 
—onnnn a MbetS S 
$7995 FULL KIT 
w/100 Page Manual 
ADD $40 FOR A&T 
OPTIONAL EPROM FOR 


PC/XT STYLE SERIAL 
KEYBOARD: $15 


SOURCE DISKETTE: 
PC/XT FORMAT 


TERMS: Add $3.00 postage. Orders under $15 add 75¢ handling. No 
C.0O.D. We accept Visa and MasterCard. Tex. Res. add 6-1/4% Tax. 
Foreign orders (except Canada) add 20% P & H. Orders over $50 add 85¢ 
for insurance. 


WE ARE NOT ASSOCIATED WITH DIGITAL RESEARCH INC. (CALIF.) THE SUPPLIERS OF CPM SOFTWARE 


Software Review 


DRI’s Multitasking, Multiuser 


The 32-bit 80386 chip from Intel has been 
the talk of the town among programmers 
and hardware designers for some time. 
Compaq was the first manufacturer to 
ship an 80386-based system (DeskPro 
386), which is AT compatible. Recently, 
many clone manufacturers have intro- 
duced 80386 systems as part of their prod- 
uct line. Unfortunately, however, no soft- 
ware has existed to take advantage of the 
80386 architecture. The 8086 PC-DOS/ 
MS-DOS operating system can be used on 
the 80386, but in real mode, which means 
that it cannot use the advanced features 
for which the 80386 chip is intended. Digi- 
tal Research, in the meantime, has been 
producing the Concurrent DOS 86 multi- 
tasking, multiuser operating system for 
use with the 8086 (see MS/J, May/June 
1987) for over two years. Now, the British 
office of Digital Research, Inc. (DRI) has 
modified Concurrent DOS 86 to take ad- 
vantage of the 80386 chip and has recently 
introduced Concurrent DOS 386, an 
80386 operating system that truly uses the 
80386 advanced features. DRI provided us 
with a copy of its new operating software 
and we put it through its paces. 
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386 Operating System 


by Alex K. H. Soya 


The 80386 Chip 

The Intel 80386 chip is a 32-bit micropro- 
cessor designed primarily to support 
multitasking, multiuser operating systems 
and high-level languages. Thus it offers 
features useful to implementing operating 
systems and high-level languages. 

The 80386 is compatible with the ear- 
lier 8086 and 80286 processors. To remain 
compatible with its predecessors, the 
80386 processor can run in one of several 
modes. 

Real mode refers to the 8086-compati- 
ble mode of operation. When it is reset, the 
processor is placed into real mode. In this 
mode the 80386 looks just like the 8086 
chip. As noted, the PC-DOS/MS-DOS op- 
erating system runs on 80386-based sys- 
tems in real mode. 

The 80386 protected mode is a superset 
of the 80286 protected mode functions. The 
additional functions include memory pag- 
ing, a larger addressing space, an enhanced 
Task State Segment (TSS), and more so- 
phisticated I/O privilege functions. 

The most useful mode from the user’s 
point of view is the virtual 8086 mode. In 
this mode the 80386 offers full compatibil- 


The Concurrent DOS 386 from DRI offers an 
operating system designed for the 80386's ad- 
vanced features. 
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386-DOS™ 


A MULTITASKING, MULTIUSER CONCURRENT™-BASED OPERATING SYSTEM 


386-DOS™ from Concurrent Controls, Inc. is a multitasking, multiuser operating 
system for 80386-based microcomputers that combines power and flexibility with an 
easy-to-use interface and a virtually unlimited capacity for growth. 


POWER FLEXIBILITY 

Supports up to 16 MB of RAM Use PC-DOS media and commands 
Utilizes power of 80386-based machines Use with your choice of serial port board 
Supports 1 to 19 users Configure each serial port as a terminal, 
3 parallel printers and 1-18 serial printers printer, device or remote. 

Supports intelligent I/O boards for User configurable |RQ lines, polled or 
increased performance interrupt driven, and port buffer size. 
EASE OF USE SUPPORT 

Familiar PC-DOS interface and commands Prompt, professional phone support 
Continue to use many PC-DOS programs Dealer, system integrator and 
Menu-driven installation and maintenance programmer levels of support available 


CCI provides versions of 386-DOS“ optimized for use with many vertical market 
solutions such as INMASS™ BRAVO™~ and _ Digital Dining™. With 386-DOS™ your 
installations can grow from a multitasking, single-user station to a multiuser system and 
can be networked at any time — all on the same operating system — reduce learning 
curves and training time — increase VAR upgrade sales & profits. 


AVAILABLE NOW! SPECIAL SUPPORT FOR WYSE FLASHER™ I/O BOARD! 
COMING SOON - SMARTSCREEN™ - WITH SUPPORT FOR PC-DOS PROGRAMS AT YOUR MULTIUSER STATIONS! 


Concurrent is a trademark of Digital Research Inc. FLASHER is a trademark of Wyse Technologies, INMASS is a registered trademark of MC Software, Inc. , BRAVO is a 
trademark of Armour Systems, Inc, Digital Dining is a trademark of Menusoft, 386-DOS and SMARTSCREEN are trademarks of Concurrent Controls, Inc. 


CONCURRENT DOS MULTIUSER, NETWORKING AND PROCESS CONTROL SPECIALISTS 
CDOS MODIFICATIONS - CUSTOM DESIGN - CONSULTING - TROUBLESHOOTING - C LANGUAGE TECHNOLOGY 


CONCURRENT CONTROLS, INC. (415) 648-2174 


3770 24th Street, Suite 206, San Francisco, CA 94114 FAX (415)648-0340 


ity to 8086 applications, while the operat- 
ing system can take advantage of the 32- 
bit features, including the larger address- 
ing space, paging, protection, and 
multitasking features. 

To get a more detailed description of 
the 80386 and its specific features, consult 
the Intel 80386 programmer’s guide. 


Concurrent DOS 386 Installation 

Concurrent DOS 386 is shipped on four 
5%-inch PC-DOS/MS-DOS formatted 
floppy disks. The installation procedure is 
simple. The user boots the system on the 
first disk and answers a few straightfor- 
ward questions on easy-to-read menus. 


The major 
advantage of 
Concurrent DOS 386 
compared to the 
8086 version of the 
operating system 

is its ability 

to take advantage 
of the 80386 memory 
management 
functions. 


Concurrent DOS 386 allows for many cus- 
tom-made options. The user may select 
among language, keyboard, and printers 
for various international versions of clones. 

The supported languages are: English 
(American), English (British), French, 
German, Danish, Norwegian, Swedish, 
Italian, and Spanish. By selecting a par- 
ticular language, the user ensures that the 
proper character set (with any special char- 
acters) will be loaded. Some of the prompts 
are displayed in the selected language. 

Other items that may be selected in- 
clude disk drive characteristics, color 
monitor scroll mode, and serial port 
assignments. 

I installed Concurrent DOS 386 on a 
Compaq DeskPro 386 with a 40-Mbyte 
hard disk. The operating system supports 
both PC-DOS/MS-DOS and CP/M me- 
dia type drives. At first I installed Concur- 
rent DOS 386 to use the entire 40-Mbyte 
drive as a single PC-DOS/MS-DOS media 
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partition. However, with this configura- 
tion PC-DOS/MS-DOS could no longer 
access the hard disk, as PC-DOS/MS- 
DOS limits the partition size to 32 Mbyte. 
I thus repartitioned the hard disk into two 
PC-DOS/MS-DOS partitions: 32 Mbyte 
as drive C and the remainder as drive D. 
Concurrent DOS 386 allows partition edit- 
ing with its own version of FDISK.EXE. 


The User Interface 

Concurrent DOS 386 may be booted from 
a floppy disk or from the hard disk. On the 
hard disk it is possible to boot Concurrent 
DOS 386 directly when the power is 
switched on, or after booting PC-DOS/ 
MS-DOS by typing LOAD386. I set up my 
own system to boot Concurrent DOS 386 
directly from the hard disk and to boot 
PC-DOS/MS-DOS from a floppy for those 
rare times when I want to run PC-DOS/ 


MS-DOS. 

The command line interface to Concur- 
rent DOS 386 is identical to that of Concur- 
rent DOS 86 XM. I thus felt immediately at 
home and did not have any difficulties in 
finding my way around the system. (For a 
detailed review of Concurrent DOS XM, re- 
fer to MS/J, May/June 1987.) 

Concurrent DOS 386 has the same utili- 
ties as Concurrent DOS 86: FILE MAN- 
AGER, a screen-oriented file and applica- 
tion manipulator; CARDFILE, an 
electronic index card manager; DREDIX, 
a simple full-screen editor; WMENU, a 
window manager that allows window 
sizes, location, and colors on virtual con- 
soles to be varied; and RUNMENU, a 
menu manager that allows the system 
manager to design fancy menus to guide 
the user through applications without ever 
having to issue a single DOS command. 


Figure 1. The memory map for the application looks identical 
to that of the PC environment—the bottom 1 Mbyte contains 
the operating system image, the application memory space, 
video RAM, and application memory. 


PAGE FRAME 


VIRTUAL 
APPLICATION 
SPACE 
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Concurrent DOS 386 
Memory Paging Scheme 
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EMULATION 


MEGA BYTES 
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Let's Get Technical 

Concurrent DOS 386 allows existing PC-DOS/MS-DOS applica- 
tions, as well as CP/M-86 and native mode Concurrent DOS 
applications to run in a multitasking, multiuser environment. The 
major advantage of Concurrent DOS 386 compared to the 8086 
version of the operating system is the way in which memory man- 
agement functions are performed. 

Under Concurrent DOS 86, the directly addressable memory 
was limited to 1 Mbyte, plus up to 8 Mbytes of paged memory 
conforming to the LIM/EEMS (Lotus, Intel, Microsoft/En- 
hanced Expanded Memory Specification). The 80386 version, 
however, uses 80386 memory management functions to perform 
paging of up to 4,000 Mbytes (or 4 gigabytes) of physical mem- 
ory into the virtual application space. In reality, the amount of 
memory is limited by the physical restrictions of the hardware— 
in the case of a Compaq Deskpro 386, this is 16 Mbytes. In the 
near future, we should see systems that exceed this limit. 

To the application, the memory map looks identical to that of 
the PC environment. The bottom | Mbyte contains the operating 
system image, the application memory space, video RAM, and 
BIOS ROMs. The remaining 3,999 Mbytes may be used as paged 
application memory. When Concurrent DOS 386 assigns mem- 
ory to a process, it sets up a memory page descriptor that can be 
used by the 80386 paging registers to map any 16K chunk of 
physical memory to any area in the application space. When a 
task switch occurs, the paging registers are loaded to point to the 
physical memory pages belonging to the next process serviced by 
the CPU. Figure 1 shows a graphic representation of the paging 
memory mechanism. 

This scheme allows several applications to run within their own 
1-Mbyte addressing space. But what about applications that need 
more than 1 Mbyte of memory? In the PC-DOS/MS-DOS envi- 
ronment, such applications (for example, Symphony) use EMS 
memory from specially designed EMS memory cards. Concurrent 
DOS 386 emulates the LIM specification and thus allows applica- 
tions designed to take advantage of EMS cards to work correctly 
under Concurrent DOS 386. 


Compatibility 

As there is already a wealth of software available for PC-DOS/ 
MS-DOS and Concurrent DOS XM, it is important that Concur- 
rent DOS 386 be able to use the existing software base. Many of 
the multitasking operating systems (including Microsoft’s an- 
nounced ADOS) will not run existing applications. Under Con- 
current DOS 386 two modes of compatibility must be considered: 
(1) native mode Concurrent DOS applications and (2) PC-DOS/ 
MS-DOS applications. 

In Concurrent DOS native mode, applications have access to 
advanced operating system features. Many of these features are 
intended for multiuser applications and include items such as 
shared file access, file/record locking, interprocess communica- 
tions, resource management, and many more. I tested Concurrent 
DOS 386 with several native mode applications including 
CALLME, my own remote console manager software. CALLME 
uses some very sophisticated techniques to make itself an exten- 
sion to the operating system. I did not expect it to run under Con- 
current DOS 386 without modification and thus was surprised 
when it did. Other Concurrent DOS applications I tested included 
New Word 3.1 from New Star Software (recently acquired from 
Micropro, which now markets the PC-DOS/MS-DOS version of 
New Word as Wordstar Version 4), CP/M-86 Turbo Pacal by 
Borland, Aztec-C by Manx Software, Spell Binder from Lexisoft, 
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Introducing 
multi- are | 
communications 
boards 400% 
faster than 

what youre 
sage using 


Introducing the 
DIGIBOARD COM/Xi Series front-end processor. 
Intelligent multi-channel communications boards 
400% faster than the industry standard. 
Like our popular COM/X Series, they provide 
users of PC/XT/AT-compatible computers with four 
or eight individually addressable serial ports. But 
with the new COM/Xi series we’ve added: 
¢ an 80188 co-processor operating at 10 MHz 
¢ 256K of dual-ported RAM + 16K of ROM, all 
accessible to user/ programmers for application 
and security software development 

¢ a modular design that allows us to custom- 
tailor I/O to individual customer requirements. 

On-board intelligence means more speed for 
multi-user operating systems and multi-channel 
data collection and dissemination. 

And makes the new DIGIBOARD COM/Xi 


Series a more intelligent choice for you. 


Di — 
Oli Plugging you into Tomorrow. 


Call 1-800-344-4273. In Minnesota, (612) 922-8055. 
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and many public domain Concurrent DOS 
applications. All ran quite well. I am con- 
fident that the native mode of Concurrent 
DOS 386 is identical to that of its 8086 
counterpart. 

The PC-DOS/MS-DOS emulation un- 
der Concurrent DOS 386 seems to be even 
better than that of the 8086 version. On 
my test list were GEM, Wordstar 4.0, 
Supercale 3, dBASE 2, Turbo Pascal, and 
a multitude of public domain and share- 
ware applications. I had trouble with a few 
games that were written using timing 
loops rather than the system clock. These 


Z80 Turbo Modula-2 


Z-Tools 


PUBLIC ZRDOS 


DSD 


Quick Task 


development. 


Echelon, Inc. 


885 N. San Antonio Road « Los Altos, CA 94022 
415/948-3820 (Order line and tech support) Telex 4931646 
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¢ Z Best Sellers - 


(1 disk) 
The best high-level language development system for your Z80- 
compatible computer. Created by a famous language developer. High 
ileal advanced features; includes editor, compiler, 


complete ‘7Z-System for virtually ny Z80 
computer presently running CP/M 2. 2. In minutes you can be dia 


Includes 80+ utility programs and ZCPR3: ‘The Manual 


(4 disks) — 
A bundle of software tools individ priced at $260 total. Includes 


and ITOZ/ZTOI source code converters. HD64180 support. 


qa disk) 
If you have acquired: ZCPR3. io your Z80-compatible system and want 
to upgrade to full. Z-System, all you need is ZRDOS. ZRDOS features 
elimination of.control-C after disk change, public directories, faster 
execution th: CP/M, archive status for easy backup, and more! 


(1 disk) | 

The premier debugger for your 8080, Z80, or HD64180 systems. Full 
screen, with windows for RAM, code listing, registers, and stack. We 
feature ZGPR3 versions of this professional debugger. 


(3 disks) 
Z80/HD64180 multitasking realtime executive for embedded com- 
puter applications. Full source code, no run time fees, site license for 
Comparable to systems from $2000 to $40,000! 
Request our free Q-T Demonstration Program. 


games were so fast that they were impossi- 
ble to play. 

PC-DOS/MS-DOS applications that 
give trouble in any multitasking, multiuser 
environment are TSRs (terminate-and- 
stay-resident). These applications usually 
attempt to overlay interrupt vectors or 
portions of the PC-DOS/MS-DOS operat- 
ing system. In a multitasking environ- 
ment, such a practice is quite dangerous. 
Not all TSRs, however, are doomed to fail- 
ure. Well-behaved TSRs work well under 
Concurrent DOS. 

Terminate-and-stay-resident applica- 


$89.95 


$119. 00 


$169.00 


$59.50 


$129.95 


~ $249.00 


Z-System OEM inquiries invited. 
Visa/Mastercard accepted. Add $4.00 
shipping/handling in North America, actual 
cost elsewhere. Specify disk format. 


tions may be written for the Concurrent 
DOS native mode by detaching a process 
from the console. The difference between 
native mode detaching and PC-DOS/MS- 
DOS stay-resident functions is that native 
mode processes can continue execution in 
the background. Through the use of 
queues and system flags, other processes 
may send signals to the detached process. 

Even though Concurrent DOS is a 
multitasking, multiuser operating system, 
PC-DOS/MS-DOS applications are not 
written for a multitasking environment. It 
is thus not possible to get a PC-DOS/MS- 
DOS application to share the same files 
across several terminals. Only native mode 
Concurrent DOS applications can do this. 

The version of Concurrent DOS 386 
supplied for this review emulated the PC- 
DOS/MS-DOS version 2.1 environment. 
According to DRI, Concurrent DOS 6.0, 
which should add PC-DOS/MS-DOS 3.3 
compatibility, is in development. This 
means that future versions of Concurrent 
DOS 386 will implement the PC-DOS/ 
MS-DOS 3.3 file/record locking func- 
tions, thus allowing multiuser PC-DOS/ 
MS-DOS applications to be used. 

The 8086 version of Concurrent DOS 
uses the commands COMSIZE and ADD- 
MEM to allocate memory partitions to 
DOS applications. Under Concurrent 
DOS 386 these commands still exist but 
behave slightly differently. By default, the 
entire virtual application space (between 
300K and 400K, depending on configura- 
tion) is assigned to the DOS program. 
ADDMEM and COMSIZE are now used 
to reduce the amount of memory assigned 
to DOS applications, rather than to add 
memory (as is the case with the 8086 ver- 
sion of Concurrent DOS). As the applica- 
tion space is paged out during context 
switches, this scheme is easier to handle 
from the user’s point of view. 


Networking 

Local area network (LAN) support is avail- 
able under Concurrent DOS 386 through 
the use of the already existing DRNET 1.2 
network interface software. Through 
DRNET, multiple Concurrent DOS—based 
workstations may communicate with one 
another. DRNET supports Arcnet, Ether- 
net, Token-Ring, Omninet, and, if speed is 
not important, even RS-232. 

My personal system is based on Arcnet 
cards from CompuPro and Standard Mi- 
crosystems. I have an 80286-based 
CompuPro under Concurrent DOS 5.0 
with 130 Mbytes of hard disk storage, a 
CSS AT clone running Concurrent DOS 
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5.1 XM with a 27-Mbyte hard disk, a 
floppy-based PC under PC-DOS/MS- 
DOS with CompuPro CPLINK, and the 
DeskPro 386 under Concurrent DOS 386 
with the 40-Mbyte drive, all hooked to- 
gether over the network. This gives me a 
total on-line storage of 200 Mbytes on any 
of the above systems, even the floppy- 
based PC. 

The procedure for adding the network 
software to Concurrent DOS 386 is identi- 
cal to that for adding it to Concurrent 
DOS 86. The version of DRNET used for 
Concurrent DOS 86 is used with Concur- 
rent DOS 386 as well. 

Setting up a network system is not a 
trivial task, it requires some careful plan- 
ning and thought in order to allow maxi- 
mum utilization of available resources. 
DRNET 1.2 works well in this environ- 
ment. One of the major advantages of 
DRNET under Concurrent DOS versus 
PC-DOS/MS-DOS-based networks is that 
no special network versions of application 
software are needed. The network mecha- 
nism is completely transparent to the 
applications. 

Also, each node in the network may be a 
server as well as a client. There is no need 
for a dedicated server system. It is thus 
possible to log in from any node into any 
other node. 

Devices that may be mapped across the 
network include printers, disk drives, and 
queues. Through the use of mapped 
queues, processes can communicate with 
each other over the network. Thus it is fea- 
sible to use separate CPUs to work on por- 
tions of the same application. This feature 
is useful for multiprocessor environments. 


Summary 

The 80386 CPU provides many sophisti- 
cated features not possible with 8086- 
compatible operating systems. Concurrent 
DOS 386 provides a multitasking, multi- 
user environment with downward compat- 
ibility for applications from 8086 environ- 
ments by letting these applications run in 
the virtual 8086 mode. 

The major advantage of Concurrent 
DOS 386 is its ability to take advantage of 
the 80386 memory management func- 
tions. The multitasking, multiuser ability 
of Concurrent DOS 386 allows expensive 
resources to be shared in a cost-effective 
manner. Another important advantage to 
business users is that the operating system 
offers a familiar user interface; this makes 
training personnel already familiar with 
PC-DOS/MS-DOS or the 8086 version of 
Concurrent DOS unnecessary. § 
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Alex Soya is Manager of Research 
and Development at Concurrent Re- 
search, Inc., Satellite Beach, Florida, 
where he is responsible for the develop- 
ment of computer applications aimed at 
multiuser environments. He holds a de- 
gree in computer science from the Flor- 
ida Institute of Technology and his inter- 
ests include operating systems, data 
communications, system utilities, real 
time and scientific programming. 


Product Information 
Concurrent DOS 386 
3-user version: $395 
10-user version: $495 


Digital Research Inc. 
60 Garden Ct. 
Monterey, CA 93942 
(408) 646-3896 


If You Have Turbo C You Have 


Half Your C-Programming Vehicle 


Turbo C is a great compiler but there is 
one vital cog missing — debugging. 
Without it, you have to spend an awful 
lot of energy to go a short distance. 


Gimpel Software's C-terp, long recog- 
nized as the leading C interpreter, now 
fully supports Turbo C with com- 
plete compatibility guaranteed. 


Interactive Debugger — Our 
debugging facilities include split 
screen (code in upper portion, 
dialog in lower), breakpoints 
(sticky, temporary, line/function, cursor- 
directed), display of structures and arrays, 
execution of any expression (even those 
involving macros), function traceback 
with arguments, watch expressions and 
watch conditions (watchpoints). Our 
watch expressions can be structs or 
arrays. We catch out-of-bounds pointers! 


No Toy — Full K&R with ANSI enhance- 
ments. Multiple-module with a built-in 
automatic make. It has virtual memory 
option (with optional direct use of ex- 
tended memory) and a shared symbol 
option for those big programs. It supports 
graphics, dual displays and the EGA 
43-line mode. 


Links to external libraries — (both code 
and data, automatically) which can call 
back to interpreted functions. Function 
pointers are compiler compatible. 


100% Turbo-C compatible. —Same 
header (.h) files, data alignment, bit field 
orderings and preprocessor variables as 
your compiler. We link in your com- 
piler’s library. 


Our reconfigurable editor — is multifile 
and comes with a configuration script to 
mimic Turbo’s editor. 


The missing wheel that will 
turn your half-cycle into a bicycle 


C-terp 


Order C-terp today! 
Call (215) 584-4261 


Introductory Price for Turbo C-terp: 
$139.00 


VISA, MC, COD —30 day money back 
guarantee 


C-terp Version 3.0 is also available for the 
following compilers: 

Microsoft, Lattice, Aztec, C86, and Mark 
Williams ($298) and Xenix ($498). 


Ms 


CiMPEL SOFTWARE 


3207 Hogarth Lane 
Collegeville, PA 19426 


C-terp is a trademark of Gimpel Software, and Turbo C of 
Borland International 
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Hardware Review 


Intel 


Inboard 386 


Upgrade a PC/AT to the 80386 with a 


When Compaq introduced its 386 system 
in September of 1986, I began to think of 
switching to a 286-based IBM PC/AT but 
the price seemed a little steep. Also, hav- 
ing previously been burned by “advanced 
technology,” I was concerned that critical 
programs might not run on the Compaq 
and I would be stuck with a white 
elephant. 

So when Intel announced the Inboard 
386, a plug-in 386 processor board for the 
IBM PC/AT, it aroused my interest. I 
could upgrade rather than 
scrap my current system, and 
if any programs would not 
run, I could just remove the 
Inboard, converting the sys- 
tem back to its previous 
capabilities. 

The Intel Inboard 386 is a 
full-length plug-in accelera- 
tor card for converting an 
IBM PC/AT from a 16-bit 
80286-based system into a 
32-bit 80386-based system. 
It also adds some functional 
features. Not only does it 
boost the processing speed of 
the AT, but it runs the new 
multiprocessing /multiuser 
32-bit software now coming 
to the market for 386-based 
systems. 

But could a modified AT 
dressed up with a different 


Plug-In Card 


by Hank Kee 


processor offer real advantages? The ob- 
jective of this review was to try to answer 
the following questions: 


®@Was compatibility maintained for a sys- 
tem containing interconnect boards such 
as 3278 emulators, Token-Ring adapt- 
ers, and Ethernet links? 

@ls this a real 32-bit system, or is it a 
warmed-over 16-bit system? 

@What software can take advantage of 
such a system? 


Intel’s Inboard 386, a plug-in processor board to upgrade the IBM PC/AT 


Benchmarking the Inboard 

Intel provided me with one of its early pro- 
duction Inboard 386 cards. The first thing 
I did was run some of the standard speed 
benchmark tests used to evaluate XT- and 
AT-compatible systems. The tests I ran 
were the CPU2, Landmark, and MIPS 
tests, all of which are in the PC/Blue and 
some other public domain software librar- 
ies. | was also able to run the tests on the 
Compaq 386 system that was available. 
The results indicate that an IBM PC/AT 
equipped with the Intel In- 
board 386 is comparable in 
performance to a Compaq 
386, if not slightly better 
(Figures | and 2). 


Installation 
Installing the Inboard 386 is 
not difficult, but it can be a 
} bit perplexing. First, the 
80286 processor chip has to 
be removed from the AT 
motherboard. A connecting 
ribbon cable containing a 
logic circuit is then installed 
from the original 80286 
socket to the Inboard card. 
The interconnecting cable 
provided with the Inboard is 
designed specifically for sys- 
tems that are physically and 
electrically compatible with 
the IBM PC/AT. Some AT- 
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tion. Without the expense or hassle 
of adding another PC with compli- 
cated LAN gear. And since each 
user's computer is placed inside 
your central PC, you get much 
better control and security. 

QuickLink uses the 
industry-standard Novell Netware 
operating system, so you have access 
to all Novell multi-user applications 
plus the entire world of single-user 
PC programs. You get electronic 
mail, printer sharing, mainframe- 
like security, file and record lock- 
ing, and much more. 


meet | So lower your LANing 
! | | | a7 gear by calling TNL or your local 
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dealer today. We'll show you how to 
turn your PC into a 
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Quicklink” 
From The Network Link™ 


3303 Harbor Blvd., Building H-10, Costa Mesa, CA 92626. (714) 549-9380 
QuickLink developed by InterContinental Microsystems Corp. and manufactured for TNL. 
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COMBINE THE 
RAW POWER OF FORTH 
WITH THE CONVENIENCE 
OF CONVENTIONAL LANGUAGES 


HS 
FORTH 


Yes, Forth gives you total control of your 
computer, but only HS/FORTH gives you 
implemented functionality so you aren't left 
hanging with “great possibilities” (and lots of 
work!) With over 1500 functions you are 
almost done before you start! 

WELCOME TO HS/FORTH, where megabyte 
programs compile at 10,000 lines per minute, 
and execute faster than ones built in 64k 
limited systems. Then use AUTOOPT to 
reach within a few percent of full assembier 
performance — not a native code compiler 
linking only simple code primitives, but a full 
recursive descent optimizer with almost all of 
HS/FORTH as a useable resource. Both 
optimizer and assembler can create inde- 
pendent programs as well as code primitives. 
The metacompiler creates threaded systems 
from a few hundred bytes to as large as re- 
quired, and can produce ANY threading 
scheme. And the entire system can be saved, 
sealed, or turnkeyed for distribution either on 
disk or in ROM (with or without BIOS). 
HS/FORTH is a first class application devel- 
opment and implementation system. You can 
exploit all of DOS (commands, functions, 
even shelled programs) and link to .OBJ and 
.LIB files meant for other languages inter- 
actively! 

1/O is easier than in Pascal or Basic, but much 
more powerful — whether you need parsing, 
formatting, or random access. Send display 
output through DOS, BIOS, or direct to video 
memory. Windows organize both text and 
graphics display, and greatly enhance both 
time slice and round robin multitasking utili- 
ties. Math facilities include both software and 
hardware floating point plus an 18 digit 
integer (finance) extension and fast arrays for 
all data types. Hardware floating point covers 
the full range of trig, hyper and transcenden- 
tal math including complex. 

Undeniably the most flexible & complete 
Forth system available, at any price, with no 
expensive extras to buy later. Compiles 79 & 
83 standard programs. Distribute metacom- 
piled tools, or turnkeyed applications royalty 
free. 


HS/FORTH (complete system): 

HS/FORTH: Tutorial & Ref (500 pg) 

Forth: Text & Reference (500 pg) 

HS/FORTH Glossary 

GIGAFORTH Option (Beta release) 245 
(Native Mode from SOFTMILLS, INC.) 


"art Visa 


HARVARD 
SOFTWORKS 


PO BOX 69 
SPRINGBORO, OH 45066 
(513) 748-0390 


Mastercard | es 
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compatible systems use a different 286 chip 
package and will require a different inter- 
connecting cable. The Sperry Micro IT, 
AST AT, and the Compaq 286, for exam- 
ple, all require the nonstandard LCC cable 
(also available from Intel). Also, some so- 
called AT compatibles do not have remov- 
able 286 processor chips or have different 
bus structures (such as the AT&T 6300+ ) 
and hence cannot be converted. It is advis- 
able to check with Intel if you are unsure 
about system compatibility. 

The Inboard is available with OK mem- 
ory (you can populate the rest yourself at a 
much lower cost) or 1 Mbyte of factory- 
installed on-board memory. Also available 
is a 2-Mbyte daughter board to bring the 
Inboard up to a total capacity of 3 Mbytes. 

The Inboard will work with OK of mem- 
ory using the memory on the AT mother- 
board. Performance suffers, however, 
dropping to half that achievable with on- 
board memory. The memory on the In- 
board functions as a 32-bit wide memory 
system with a memory caching circuit. 
When there is no on-board RAM, the 386 
uses the standard 16-bit-wide memory sys- 
tem that does not have caching, and so 
performance suffers. 


Connectivity and Compatibility 

Since I connect systems to LANs and 
mainframes, I am concerned with connec- 
tivity—in other words, connecting the sys- 
tem to the outside world via different com- 
munication adapter boards. All too often 
this is a crucial test for PC-compatible sys- 
tems. I have found that many so-called 
compatibles cannot support the IBM To- 


ken-Ring or IBM 3278 emulation adapters. 
I was therefore pleased to see that an IBM 
PC/AT equipped with the Intel Inboard 
functioned properly with the Token-Ring 
and 3278 adapters installed. 

Software compatibility was another 
concern. I ran many of the standard PC 
application programs without any prob- 
lem. But my prime interest was in the new 
386 software. Since this software was de- 
signed to run on a Compaq 386, I was in- 
terested to see if there would be problems 
running 386 programs on a converted AT. 

I tested Quarterdeck’s new release of 
DESQview (Version 2.0 with the 386 ex- 
tension), Concurrent DOS 386 from Digi- 
tal Research (DRI), and PC-MOS/386 
from Software Link. All three operate in 
the true 80386 32-bit mode and provide 
multitasking /multiuser facilities. After 
testing each, I began wondering why there 
should be so much interest in OS/2, which 
is only a 286-based operating system. 

DESQview operated in much the same 
way as the existing PC version. In fact, 
regular extended or EMS memory works 
just as EEMS does. Each task can be max- 
imized for memory utilization. Up to 255 
tasks could be initiated under DESQview, 
provided the resources are there. (Any- 
thing more than a dozen would just be an 
academic exercise.) It worked well. Pro- 
grams need not be well behaved to func- 
tion. Best of all, I was not dependent on a 
mouse in order to run a few tasks. Using 
Inboard with DESQview was like having a 
window to the world with computerized 
speed and multitasking. 

DRI’s Concurrent DOS 386 operating 


Figure 1. Benchmark test results 
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Repetition 
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Landmark CPU speed test: Speed version .99 
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system was also a delight to operate. Al- 
though designed for the Compaq 386, the 
Inboard had no problem running it. Most 
PC-DOS programs ran concurrently with 
no problems since Concurrent DOS 386 
provides DOS Version 2.x compatibility 
(Version 3.x compatibility is reportedly be- 
ing developed). Only programs that went 
into selective operating system calls were 
vulnerable to failure. The copy I tested was 
a beta-test copy, yet the product appeared 
to be in a finished form since all the fea- 
tures were there and I encountered no bugs. 

I also tested a beta copy of Software 
Link’s PC-MOS/386 operating system. 
This product was designed for the Com- 
paq DeskPro-386, as well, but there was 
no problem installing and running it on the 
Inboard. PC-MOS/386 appears, however, 
to need further development, which will no 
doubt happen with its formal release and 
subsequent updates. 

I am not a speed enthusiast and I am not 
particularly concerned with multitasking, 
but there are times when I wish I could 
have a little more processing speed and the 
ability to run another task in the back- 
ground without seriously affecting per- 
formance. The combination of the Intel 
Inboard 386 with an AT-compatible sys- 
tem seems like a very logical approach. 


Summing Up 

The Intel 80386 provides the increase in 
performance that has been sorely needed 
for true multitasking on the PC. The 
Compaq 386 was the first system to de- 
liver this level of performance, but at a 
price. The Intel Inboard 386 provides an 


alternative upgrading to a Compaq 386 
for those who already own an IBM PC/AT 
or compatible system. § 


Hank Kee is in charge of computer sup- 
port at a large banking institution. He is 
also co-librarian of the PC/Blue public 
domain software library, and operates the 
New York Amateur Computer Club elec- 
tronic bulletin board system ([718] 539- 
3338 or [718] 539-3560). 


Product Information 


Connecting Cables 

PCIB3001—for IBM PC/AT $200 
PCIB3002—-for AT-compatibles $200 
Intel Inboard 386 AT 

(less connecting cable) 

PCIB3000—-0K memory $1795 
PCIB3010-——1-Mbyte RAM $2295 


Intel Personal Computer-Enhancement 
Operation 

Mail Stop CO307 

5200 N.E. Elam Young Pkwy. 
Hillsboro, OR 97124 

(800) 538-3373 


80387 Math Coprocessor 
PCNC8387-16 $795 
Piggyback Memory Boards 
PCIB3110—1 Mbyte on board 
(2 Mbyte in system) 
PCIB3120-——2 Mbyte on board 
(3 Mbyte in system) $1145 


$645 


Figure 2. MIPS (from Chips and Technologies, Version 1.20) 
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dBASE Programmers 


You need it! 
CR You can handle it! 
(7 dB2c is here now! 


dB2c Offers: 

* Version 2.0 complete with 
Translator and File 
Handlers. 

* Extensive implementation 
of dBASE Ill+ with over 200 
functions and commands in 
C source code. 

* Contains our own File 
Handlers plus interfaces for 
Lattice's dBC and Faircom's 
c-tree. 

* Supports screen I/O with 
ANSI.SYS or fast assembler 
routines. 

* Support for Microsoft, 
Lattice and Turbo C 
compilers. 

* Tutor features of translation 
combined with familiar 
syntax of the library eases 
the transition to 'C’. 

* One version supports MS- 
DOS, Xenix, Unix, OS-9 

* and Concurrent DOS. 


are you 
ready? 


elle>< 


Toolkit $299 


Call or Write: 
SOFTWARE 
CONNECTION, INC. 
POB 712, Ely, MN 55731 
(218) 365-5097 


37 


The Software Link’s 
PC-MOS /386 


A Low-cost 
80386 
Multitasking, 
Multiuser 
Operating System 


Every day we hear of more 80386 micro- 
computer systems being introduced. It 
seems a given in the industry that software 
always lags far behind hardware. An ex- 
cellent example is IBM’s PC/AT, an 
80286-based system introduced in 1984, 
and the operating system for it, OS/2, 
which will not be available until 1988—a 
four-year lag. With the 80386 systems, 
however, such is not the case. 

Within nine months of the introduction 
of the first 80386 system (the Compaq 
DeskPro 386), several 80386 operating 
systems have been announced. I would like 
to introduce and give an overview to one of 
these systems, PC-MOS/386, from The 
Software Link. The Software Link is best 
known for MultiLink and LanLink, two 
networking products that run in conjunc- 
tion with PC/MS-DOS. PC-MOS/386 
(referred to as “MOS” in the balance of 
this article) is the company’s first foray 
into the operating system market. 


by Charles H. Strom 


Overview 

A primary design goal of this operating 
system was to maximize compatibility 
with as many PC/MS-DOS 3.2 applica- 
tions as possible. The virtual 8086 mode of 
the 80386 allows this while taking advan- 
tage of the protected environment. Along 
with virtual mode, paging allows each 
multiple application to see the same 640K 
PC/MS-DOS address space. Lastly, MOS 
is said to support 32-bit native mode, al- 
though no examples of such code were on 
hand to test. MOS takes advantage of the 
design of the microprocessor and its ability 
to directly address large blocks of RAM to 
support both multitasking and multiuser 
operation. 


Multitasking 

Three versions of the operating system 
support one, five, and twenty-five users. 
Actually, “MOS” stands for modular op- 
erating system; it is easy to upgrade to the 
multiuser versions by simply adding a 
module. In all cases, multitasking is avail- 
able (within the limits of available RAM) 
by defining memory partitions as needed. 
For example, an “ADDTASK 384” will 
create an additional partition of 384K. 
Keying Alt-1 will switch to partition 1, 
Alt-2 to partition 2, and so on. The maxi- 
mum partition size is approximately 
640K. Utilities are also included to remove 
or resize partitions. When more than one 
process is running—whether due to a sin- 


gle user running several tasks, several us- 
ers each running a task, or some combina- 
tion—there are two types of priority as- 
signments: (1) the SLICE subcommand 
controls the number of time slices (of ap- 
proximately 1/18 second duration) de- 
voted to each task and (2) the PRIORITY 
subcommand allows eight levels of prior- 
ity. A task with lower priority will not exe- 
cute until all higher priority tasks are com- 
plete. The power and flexibility of these 
commands illustrate the careful planning 
that went into MOS. 


Multiuser 

Many of the details discussed above can 
also be applied to multiuser configurations 
of MOS. A variety of terminals is sup- 
ported, including Zenith’s Z-19; the Tele- 
video 910, 912, 920C and 925; the ADM- 
3A, ANSI terminals; and so on. Also, any 
of the PC-compatible terminals (such as 
the Kimtron KT-7 and Wyse WY-60) can 
be used. Even dumb, teletypelike termi- 
nals can be used. Since there is provision 
for a user-defined terminal driver, almost 
any hardware will work. 

Note that MOS treats remote terminals 
as monochrome displays. At present, 
graphics are not supported because The 
Software Link has yet to develop the nec- 
essary driver, but a CGA version is ex- 
pected soon. The company does market a 
product called PC-Emulink, which allows 
a CGA-equipped computer to serve as a 
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Upgrade your technology 


The software technology available to 
programmers of IBMcompatible per- 
sonal computers is truly amazing. 
And newer, more powerful develop- 
ment packages appear all the time. 
But until now, finding out about these 
important products has been a diffi- 
cult and time consuming task. 


FREE Buyer’s Guide. The 
New 76 page Programmer’s 


Large Inventory. We have one of the 
largest inventories of programmer’s 
development products in the industry. 
Most orders are shipped within 24 
hours. 

Noncommissioned Staff. Our courte- 
ous salespeople are always ready to 
help you. And if you aren’t sure about 


your needs, our knowledgeable tech- 
nical people can give you sound, 
objective advice. 

Experience. We've specialized in de- 
velopment software for IBMcompati- 
ble personal computers since 1984 
and are experienced at providing a 
full range of quality products and 

customer services. 


How to Get Your Copy. 


Connection Fall 1987 Buy- 
ers Guide contains individ- 
ual descriptions of over 

500 titles of programmer’s 
development software by 
over 150 manufacturers. 
Each description covers 
major product features as 
well as any software or 
hardware requirements and 
version numbers. In the box 


Blaise 
C TOOLS PLUS/5.0 


List $129 Ours $99 

C TOOLS PLUS/SS.0 is a library 
for Microsoft C that can provide 
you with a full spectrum of 
eneral-purpose utility functions. 
ncluded are functions that take 
advantage of the machine fea- 
tures of IBM-compatible per- 
sonal computers and DOS and 
complement the standard com- 


editor; access to environment 
variables; a MOVE command; 
and Browse, a full screen file 
viewer. Command Plus also in- 
cludes SCRIPT, a batch processor 
that uses a Pascal-like language 
that features: integer and strin 

variables; boolean, math an 

strin operators; CALL, 
FORTW TILE, GOTO 

IF/THEN/ELSE, and SWITCH 
statements; and display and file 
access routines. Enhancements 
to DIR include sort options and 
file attrib display. COPY options 
include selection by date/time 


There are two ways for you 
to receive your FREE copy 
of the Programmer's Con- 
nection Buyer’s Guide: 1) 
Mail us a card or letter with 
your name and address; or 
2) Call one of our convenient 
toll free telephone numbers. 


If you haven’t yet received 
your Programmer’s Connec- 
tion Fall 1987 Buyer’s Guide, 


on the right are some ex- 
amples of the types of de- 
scriptions you'll find in our 
Buyer’s Guide. 


No Hidden Charges. The 
low discount prices in our 
Buyer’s Guide are all you 
pay. We don’t charge extra 
for UPS Ground shipping, 
credit cards, COD orders, 
purchase orders, sales tax 
(except Ohio) or special 


piler library, Almost all functions 
are written in C using techniques 
most suitable for good C program 
design. Some of the areas covered 
are: extensive string handling; 
screen handling inclu ad a 
for multiple monitors and the 
EGA; general utility and 
keyboard functions; DOS 
memory management; windows 
that can be stacked, removed and 
accept user input; intervention 
code; and interrupt service 
routine support for truly flexible 
resident applications. C TOOLS 
PLUS/S.0 includes all source 
code, complete examples and a 


range, and recursive sub-directory 
processing. 

_ Requires 48K memory. Ver- 
sion 1.2. 


act now. Upgrading your 
programming technology 
could be one of the wisest 
and most profitable deci- 
sions you’ll ever make. 


comprehensive reference 
manual. 

Supports Microsoft C 5.0 and 
Microsoft QuickC. 


ESP 


Command Plus 
List $80 Ours $69 


handling (except for non- 
Canadian international 
orders). 


Guarantees. We offer FREE 
30-day no-risk return guar- 
antees and 30-day evalua- 
tion periods on most of our 
products. 


Meridian 
Software CALL TOLL FREE 
AdaVantage BAS ses scars 800-336-1166 
Compiler 2.0 oanece ... 800-225-1166 
List $795 Ours $735 hio & Alaska 
The Meridian AdaVantage Com- (Collect):. .216-494-3781 


eechage) bald gba naneanr nag nd 
ation of the Ada language. The 
compiler generates native 8086 
code in the Intel standard object 
format. A linker is provided to 
create stand-alone executable 
files for MS-DOS. The Meridian 
ie id pein Compiler package 
includes the compiler, linker, 
library management tools, sup- 
port packages, runtime libraries 


International: 216-494-3781 
Telex? sss seus « 9102406879 
Easylink:....... 62806530 


Programmer’s Connection 
7249 Whipple Ave. NW 
North Canton, OH 44720 


Latest Versions. The prod- 
ucts we carry are the latest 
versions and come with the 
same manufacturer’s techni- 
cal support as if buying 
direct. 


The Free 
Programmer 


Command Plus is a powerful, 
bootable MS-DOS command 
processor fully compatible with 

OMMAND.COM. Many new 
features are included that will 
help you increase your speed, 
productivity and ease of program- 
ming. These include a history 
processor that lets you recall and 
cate pre ouly entered com- 
mands using the cursor keys. The 
alias facility allows the creation of 
command macros with replace- 
able parameters. Other features 
include: regular expressions in 
filenames; directory and argu- 
ment stacks; a command line 


and a configuration tool. In addi- 
tion to the standard Ada pack- 
ages, Support packages are 
provided to make integer, floating 
point and text I/O more con- 
venient to implement. The com- 
Pre also provides a pragma 
NTERFACE used to make calls 
to subprograms written in 8086 
assembly language, Meridian Cor 
Meridian Pascal. A source level 
eauaee will be available in late 


Requires hard disk and 640K 
memory. Runtime fees apply if 
more than 99 copies are sold. 
Version 2.0. 


sConnection 


Fall '87Buyer's Guide. 


ai-expert systems 


1st-CLASS hy Programs in Motion .............+ 
EXSYS Development Software by EXSYS......0+4+ 
EXSYS Runtime System ..............00000- 


LEVELS dy /nformation Builders ............ New 


Logic-Line Series A// varieties by Thunderstone... . . 
ai- lisp language 

Golden Common LISP dy Gold Hill .............. 
Golden Common LISP Developer by Gold Hill ...... 
O'Nial Various by MAL Systems ........000.000+ 
Star Sapphire LISP Compiler by Sapiens... . 
TransLISP PLUS from Solution Systems 


ai- prolog language 
Arity Combination Package ..................- 
Expert System Development Pkg . se 
File Interchange Toolkit... . 
PROLOG Compiler & Int 
Screen Design Toolkit ..... 
SQL Development Package 
Arity PROLOG Interpreter . 
Arity Standard Prolog ..... 
LPA microPROLOG A// Varieties... 
MPROLOG Language Primer LOGICWARE . 
MPROLOG P500 by LOGICWARE ........ 
MPROLOG P550 w/Primer by LOGICWARE 
Turbo PROLOG dy Borland Intl ......... 
Turbo PROLOG Toolbox by Borland Int! 


ai-smalltalk language 


SMM: 5 oc cosacmnsmennveceaieeweuniees 
EGA/VGA Color Option .... wis 
Goodies Diskette ......... or 
Smalltalk/Comm .............0eceeeeeees 


ai- texas instruments 


Arborist Decision Tree Software ...........0++++ 
PC Scheme Lisp............ New Version 
Personal Consultant Easy... .. New Version 
Personal Consultant Image.................+-- 
Personal Consultant Online .. . 
Personal Consultant Plus ..... 


ada language 


AdaVantage GSA-Validated by Meridian Software 
AdaVantage Utility Packages . . 
DOS Environment Package ..... 

Janus/ADA C Pak by R&R Software . 

Janus/ADA D Pak by R&R Software . ne 

Janus/ADA ED Pak by R&R Software............ 


apl language 

APL SPLUS PO by STS oso. 0:5:n)0;0:0)20.010 015:2.0,0,0:0,2)0,0 
APL*PLUS PC Spreadsheet Mgr by STSC ame 
APL*PLUS PC Tools Vol 1 ty SSC... 
APL*PLUS PC Tools Vol 2 by STSC . 
APL*PLUS PS/2 by STSC ........ 
ATLAS *GRAPHICS dy STSC ...... 
Financial/ Statistical Library by STSC 
Pocket APL by STSC ............ aCe: 
STATGRAPHICS by STSC «1.1... cece eee eee 


assembly language 


386 ASM/LINK Cross Asm by Phar lap ........45 
8088 Assembler w/Z-80 Translator by 2500 AD... . 
ASMLIB Function Library by BCSoft 
asmTREE 8-7ree Dev System by BCSoft 
Cross Assemblers Various by 2500 AD . 
EZASM by C Source...........45 
Microsoft Macro Assembler ... . . 

Turbo Debugger by Speedware . 
Turbo Editasm by Speedware . . 
Visible Computer: 8088 by Software Ma. 


basic language 


db/Lib for QuickBASIC by AJS Publishing . 
Finally by Komputerwerk............ 
MACH 2 by Micro Help .......... 
Microsoft QuickBASIC............. 
QBase Relational Database by Crescent 
Quick-Tools by BCSoft ...........4+ 
QuickPak by Crescent Software ...... 
Scientific Subroutine Library by Peerless . 
Screen Sculptor by Software Bottling .. 
Stay-Res by MicroHelp 
True Basic w/Run-time 
Meee RONG siicccecsossseaces 


‘New 


blaise products 


ASYNCH MANAGER Specify C or Pascal ......... 
CTOOLS PLUS/5.0 .............. New Version 
KeyPlayer Super Batch Program .... .. New 
LIGHT TOOLS for Datalight C...... 
PASCAL TOOLS ............... 


PASCAL TOOLS & TOOLS 2 .. 
RUNOFF Text Formatter...... 
TURBO ASYNCH PLUS ...... 
TURBO C TOOLS ............ 


VIEW MANAGER Specify C or Pascal........... : 


borland products 


EUREKA Fquation Solver ...........2..002204 
Reflex: The Analyst ............. 
BUICK oi isinnereiarsiaraie weiss 
DORN oi sictironicaneainniaierasawe 
Turbo Basic Compiler............ 
Turbo Basic Database Toolbox 
Turbo Basic Editor Toolbox ....... 


List Ours 


595 

95 
495 
4 


95 


Turbo Lightning and Word Wizard .............. 
Turbo Lightning ............ 
Turbo Lightning Word Wizard. . 

Turbo Pascal and Tutor .... 


. New Version 


Turbo Pascal .... . New Version 
Turbo Pascal Tutor ..... . New Version 
Turbo Pascal Database Tool! . New Version 
Turbo Pascal Editor Toolbox. . . . New Version 
Turbo Pascal Gameworks Toolb . New Version 


Turbo Pascal Graphix Toolbox ....... New Version 
Turbo Pascal Numerical Methods Toolbox ....Vew 
Turbo Prolog Compiler . 
Turbo Prolog Toolbox...................00085 


c compilers 


C86PLUS by Computer Innovations .........+++4+ 
DeSmet C w/Debugger & Large case . 
DeSmet C w/Debugger only........ 
Eco-C Complete System by Ecosoft . . 
Instant C by Rational Systems..... 
Instant-C/16M by Rational Systems ......... 
Lattice C Compiler vers. 3.2 from Lattice 
Mark Williams Let's C w/csd. . 
Microsoft C Compiler w/ CodeVie 
Microsoft QuickC Compiler 
Optimum-C fy Datalight .... 
Turbo C Compiler ty Borland . . 

Uniware 68000/10/20 Cross Compi 


c interpreters 


C-terp by Gimpel, Specify compiler ............4+ 
C Trainer with Book by Catalytix.... 
Introducing C by Computer Innovations . 
Run/C by Age of Reason .....-... 0c cece eeees 
Run/C Professional by Age of Reason ........... 


c utilities 


Blackstar C Library by Sterling Castle........ New 
C++ by Guidelines w/version 1.1 kernel .......... 
c-tree & r-tree Combo by FairCom .............. 

c-tree /SAM File Manager .. 

t-tree Report Generator .........00 eee ee eee 
Csharp Realtime Toolkit by Systems Guild......... 
Curses Window Dev Pkg by Aspen Scientific .. 

WAN SOMO COND scice ce ccaracau Nara eies 
dBx dBASE to C Translator by Desktop Al ........+ 

th SONS COMG . s a.cc seine csetsvssiectwhass 
Flash-up Windows by Software Bottling . 
GraphiC Color version by Sci Endeavors . 
GRAFLIB by Sutrasoft ........... 
HALO Graphics by Media Cybernetics 
HALO Development Pkg for Microsoft . . 
The HAMMER by OES Systems ...... 
PANEL Forms Management by Roundhill . 
PANEL/TC for Turbo C by Roundhill . 
PANEL Plus by Roundhill ....... 
PC Lint by Gimpel Software . 
PLOTHP by Sutrasoft............ 
RTC PLUS Fortran to C by Cobalt Blue . 
Sapiens V8 Virtual Memory Manager .... 
Scientific Subroutine Library by Peerless . 
TE Text Editor source by Sub Systems . 
Vitamin C by Creative Programming . 

VC Screen Forms Designer...... mire 
Zview by Data Mgmt Consultants .........0.0005 


cobol language 
COBOLspll by Flexus .........00..00ceeeeeees 
FPLIB for Realia COBOL by BCSoft .............. 
Micro Focus COBOL See Micro Focus Section 
Microsoft COBOL See Microsoft Section 
POST by PreLole oso Scecasenc ae uneeeam aes 
Realia COBOL with RealMENU .. 
Realia COBOL ............... 
RealCICS..............055 
RM/COBOL by Ayan-McFarland .... 
RM/COBOL 85 by Ayan-McFarland . 
RM/NET+5 by Ryan-McFarland .. 
RM/Screens ...........0. 
SCREENIO by Norcom ....... 
screenplay for COBOL by Flexus .... 2... cceuuaee 


css products 


Combo Package by Custom Software Systems 
PC/SPELL Spelling Checker . 
PC/TOOLS UNIX-like Utilities. . 
PC/VI vi Editor 2.2... .... 0s ee eee 


New 


debuggers & profilers 


386 DEBUG Cross Debugger by Phar lap ......... 
Advanced Trace-86 by Morgan Computing . 
Codesmith-86 by Visual Age......... 
DSD87 by Soft Advances ..... 
MiniProbe by Atron ........... 
Periscope | with Board by Periscope . 
Periscope II with WMI Breakout Switch . 
Periscope II-X Software only ... . 
Periscope Ill 8 MHz version ... 
Periscope Ill 10 MHz version ...... 
The PROFILER with Source Code by DWB......... 
TURBOsmith Source debugger for Turbo Pascal..... 
The WATCHER Profiler by Stony Brook ........... 


disk utilities 


Back-It by Gazelle Systems ......... New Version 
Disk Optimizer by Softlogic Systems . 
Disk Technician by Prime Solutions . 
FASTBACK by 5th Generation System. 
Veache by Golden Bow Systems 
Vopt by Golden Bow Systems .. 
Vfeature by Golden Bow Systems . 

Vfeature Deluxe by Golden Bow Syst : ean 
XenoCopy-PC by XenoSoft ..........-0. 20 cee 


dos utilities 


. New 


Desqview from Quarterdeck ...........0.0000e8 100 
FANSI-CONSOLE by Hersey Micro ...........005 75 
Mace Utilities Pau/ Mace Software .......... New 99 
MicroHelp Utility by MicroHelp . . aes 59 
Norton Commander by Peter No 75 
Norton Utilities by Peter Norton . . 100 
OPAL Shell Language by Software 99 
Q-DOS II by Gazelle Systems . . ‘ 70 
Taskview by Sunny Hill Software ..... 2.0.60 0 605 80 
essential products 
C Utility Library... 06... cece eee e eee eee 185 
Essential Comm Library with Debugger........... 250 
Essential Comm Library Software Only ......... 185 
Breakout Debugger Only Any /anguage......... 125 
Encantial Grapes ss ciesccsctertecstssecwaws 250 
forth language 
CFORTH Wative Code Compiler by LMI .......-.-+ 300 
FORTH/83 Metacompiler Specify Target ......... 750 
PC/FORTH by Laboratory Microsystems .......... 150 
PC/FORTH+ dy Laboratory Microsystems ......... 250 
Programmer's Package #1 by M/ 250 
Programmer's Package #2 by LM/ . . 350 
Programmer's Package #3 by LM/ 500 
UR/FORTH Also Available for 0S/2 by LMI ....... 350 
R/S FORTN Llrattee asic cnsiccinis esesicacenes 500 
fortran language 
50 MORE: FORTRAN dy Peerless Scientific . . 125 
ACS Time Series by Alpha Computer Service ... 495 
AUTOMATED PROGRAMMER by KGK Automated 995 
Essential Graphics by Essential Software . . 250 
Forlib-Plus by Alpha Computer Service ........... 70 
FORTLIB by Sutrasoft ... 2.0.0... cece cece eee 125 
FORTRAN Addendum by /mpulse Engr ........... 95 
FORTRAN Addenda by /mpulse Engr............. 165 
GRAFLIB by Sutrasoft ..........0220eceeeeeee 175 
HALO Graphics by Media Cybernetics .........+++ 300 
1/0 PRO w/No Limit Library by MEF ............ 250 
Microcompatibles Combo Package .............. 240 
Gre Sisce waren einconecmcnwees cnees 135 
Pletinitie aici 2eccanscrsinvincimweienamanients 135 
Microsoft FORTRAN w/CodeView .........2..4- 450 
No Limit Library by MEF Environmental ........... 129 
Numerical Analyst by MAGUS............0.0005 295 
PANEL dy Roundhill Computer Systems ........... 295 
PLOTHP dy Sutrasoft 175 
RM/FORTRAN by Ayan-McFarland . . 599 
RTC PLUS Fortran to C by Cobalt Blue . 450 
Scientific Subroutine Lib by Peerless . . 175 
Statistician by Alpha Computer Service ........+++ 295 
STATLIB.GL: by Peerless ......... 295 
STATLIB.TSF: by Peerless .......... 295 
Strings & Things by Alpha Computer Service es 70 
greenleaf products 
Greenleaf C Sampler for Turbo C & QuickC New 95 


Greenleaf Comm Library ....... «es 185 


Greenleaf Data Windows Library . 225 
with Source Code .........-- .- 395 
Greenleaf Functions...............00-+eeeees 185 
help utilities 
HELP/Control by MDS ......6.0.0ec eee eceues 125 
On-line Help from Opt-Tech ......... ae. «148 
SoftScreen/HELP dy Dialectic Systems 195 
lattice products 
Lattice C Compiler ver 3.2 from Lattice........... 500 
with Library Source Code ....... -.- 900 
C Cross Reference Generator. . ate 50 
with Source Code .........++++ 200 
C-Food Smorgasbord Function Library . . 150 
with Source Code 300 
C-Sprite Source Level Debugger . . 175 
Curses Screen Manager ........0.cecceeeeeeee 125 
with Source Code ........... --. 250 
5 | eee ereee «e250 
with Source Code ........... -.-. 600 
OBS TO PUES 006.0 ccewcinnisssiewe 750 
with Source Code ..........4+. «-. 1500 
LMK Make Facility ..........024+ sows 195 
RPG Il Combo A// three items below . 1100 
RPG II Compiler Wo Royalties 750 
SEU Source Entry Utility . . . 250 
Sort/ Merge ois jccc selec nce, ave 3200 
Screen Design Aid Utility for APG // . -.. 350 
SecretDisk Il Encryption Utility... .. 120 
SideTalk Resident Communications . . 120 
SSP/PC Scientific Subroutine Library 350 


Text Management Utilities .............-.-.-.- 120 
metagraphics products 


LightWINDOW/C for Datalight C 95 
FontWINDOW 95 
FontWINDOW/PLUS. . 275 
MetaWiNDOW Wo Roya ies. 195 
MetaWINDOW/PLUS ................00s00ee 275 
TurboWINDOW/C for Turbo C .... 2.2... eee eee 95 
TurboWINDOW/ Pascal for Turbo Pascal ........- 95 


micro focus products 
Micro Focus COBOL/2 ..................005. 900 


Micro Focus Level I! COBOL w/Animator......... 495 
Level WCOBOL  eecccsnceecieeseeuseeeten 349 
Lovell 0 AmbNOtOr: «..60.0:6'3 5:5 sisiisscesesicesead 195 

Micro Focus Level I! COBOL/ET for UNIX........ CALL 

Micro Focus PC-CICS New 1495 
with Micro/SPF ......... New 1595 

Micro Focus Personal COBOL ................. 149 

Micro Focus Professional COBOL . . --- 2000 

Micro Focus VS COBOL/XENIX .............-. 1495 


Micro Focus Support Products: 
COBOL/IO Ad hoc Report Writer ....-. 60.005 495 
COBOL/IO for DOS 3.X Networks . 
FORMS 2 ie siaisiiia.nsienaineinie 


microport products 
386 Unlimited License Kit .................... 


AT Unlimited License Kit ............ 
DOSMerge286 Aun DOS and UNIX together 
DOSMerge386 Run DOS and UNIX together 
System V/386 Combination............ 
386 Runtime System ............. 
386 Software Development System .. 
Text Preparation System .......... 
System V/AT Combination........... 
AT Runtime System .............. 
AT Software Development System . . . OF 
Text Preparation System .................-- 


microsoft products 


Microsoft BASIC Compiler for XEMX ............ 
Microsoft BASIC Interpreter for XEN/X aaa 
Microsoft C Compiler w/CodeView .... New Version 
Microsoft COBOL Compiler with COBOL Tools 

for XENIX 
Microsoft FORTRAN Optimizing Com; 
Microsoft FORTRAN for XEWIX . 
Microsoft Learning DOS ........ 
Microsoft MACH 10 with Mouse & 
Microsoft MACH 10 Board only ......... 
Microsoft Macro Assembler 
Microsoft Mouse for /BM PS/2 .......20000000% 
Microsoft Mouse Bus Version......... oe 
Microsoft Mouse Seria/ Version ..... 
Microsoft Pascal Compiler......... 

WOKEN: i Paccansteenreranuesas 


Microsoft Windows .............. ae 
Microsoft Windows Development Kit ............ 
Microsoft Word .................- New Version 


MKS AWK siidiets sana tteameaiencaeeses 
MKS RCS Revision Control System... 
MKS Toolkit with MKS Vi Editor 
MKS Trilogy with AWK, CRYPT & Korn Shell... New 
MKS VI Editor by MKS... 0. eee eee New 


modula-2 language 


LOGITECH Modula-2 Development System.... New 
Modula-2 Compiler Pack .......... .. New 
Modula-2 Toolkit........ 

LOGITECH Modula-2 ROM Pkg . 

LOGITECH Modula-2 Window Pkg . 

Macro2 Macro preprocessor by PM/ 

ModBase by PM/ .............. pace 

ModGraph ty TEQWA ... New 

Repertoire by PM/ .............-- aikinle 

Science & Engrg Tools by Quinn-Curtis . . = 

Universal Graphics Library by Quinn-Curtis ........ 


mouse products 
LOGIMOUSE BUS with PLUS Pkg by LOGITECH .... 
with PLUS & PC Paintbrush... 6.66.64. si 
with PLUS & CAD Software..... 
with PLUS & CAD & Paint... 2 
WHEN FUSE PUBESBGE 5 sie c's sais 6 80:6 sia eihiels New 
LOGIMOUSE C7 with PLUS Pkg, Specify Connector... 
with PLUS & PC Paintbrush as 
with PLUS & CAD Software 
with PLUS & CAD & Paint...... 
with First Publisher sya 
Microsoft Mouse See Microsoft Section 


other languages 


ACTOR by Whitewater Group ........ New Version 
CCS MUMPS Single-User by MGlobal ........... 
CCS MUMPS Single-User Multi-Tasking . ate 
CCS MUMPS Multi-User ............ 
Marshal Pascal by Marshal Language Sys: 
Pascal-2 by Oregon Software ......... 
Personal REXX by Mansfield Software es 
SNOBOL4+ by Catspaw....... 2.2.02. eee eee ee 


other products 


Carbon Copy Plus by Meridian Technology .......- 
Dan Bricklin's Demo Pgm by Software Garden sis 

Dan Bricklin‘s Demo Tutorial ......... 
Fast Forward by Mark Williams ..... 
Instant Replay by Nostradamus .......... 
MicroTEX 7ypesetting from Addison-Wesley arm 

Printer Drivers... 2.2 ........0 e000 New 
Net-Tools by BCSoft..........6.0008 sas 
Norton Guides Specify Language....... New 
OPT-Tech Sort by Opt-Tech Data Proc .. sits 
PC/TOOLS dy Custom Software ....... 
Screen Machine by MicroHelp ........ esate 
SuperSort by LifeStyle .........0. ese eeeee New 


Phoenix products 
Pasm86 Macro Assembler version 2.0...........+ 
Pdisk Hard Disk & Backup Utility....... 
Pfantasy Pac Phoenix Combo ......... 
Pfinish Execution Profiler ............ 
Pfix8Gplus Symbolic Debugger ........ 
PforCe Specify C Compiler ........... 
PforCe++ Specify C Compiler and C++ 
Plink86plus Overlay Linker ....... 
Pmaker Make Utility... . 
Pmate Macro Text Editor 
Pre-C Lint Utility ............ 
Ptel Binary File Transfer Program ........ 


polytron products 


PolyBoost Software Accelerator ..... Special Price 
Poly ck 1 ss scciccnwasces 

PolyDesk Ill Archivist ........ 

PolyDesk III Cryptographer .... 

PolyDesk Ill Talk............ 
PolyLibrarian Library Manager 


PolyLibrarian II Library Manager... . 1.2... .ccuee 149 
PolyMake UMIX-like Make Facility... 60... cece ene 149 
PatpShell) cc casas camenes secs Special Price 149 
Polytron C Beautifier........0-0cccceceeeeuee 50 
PolyXREF Complete Cross Ref Utility ............ 219 
PolyXREF One language only .........++0seee0e 129 
PVCS Corporate Version Control System.......... 395 


PVCS Personal ate 
program mgmt utilities 


Interactive EASYFLOW dy Haventree .. New Version 150 
Print by Software Directions ........++0.000008 89 


Quilt Computing Combo Package ............... 250 
OMake Program Rebuild Utility... ... 2.2.0.0 eee 99 
SRMS Software Revision Mgmt System ........ 185 

Sapiens MAKE & V8 ..... ° - New 439 

Sapions MAKE..........ccccsecccessecs New 179 

Source Print by A/debaran Labs ......... 6.00005 97 

TLIB Version Control System by Burton .........44 100 

Tree Diagrammer by A/debaran labs ............ 77 

raima products 

dbQUERY Single-User Query Utility..........-..+ 195 
Single-User with Source Code .............405 495 
MOUSE a scmiarna cass avis saaNSe ETN 495 
Multi-User with Source Code... ........020045 990 

dbVISTA Single-User DBMS «2.0.60. 0 000 cece eee 195 
Single-User with Source Code ...........0.005 495 
MOU SOP a ove sa ans sualeae 6 daa asco 495 
Multi-User with Source Code .........+..2+00+ 990 

sco products 

Complete XENIX System V by SCO.............. 1295 
Development System .............-00e000ee 595 
Operating System Specify XT or AT... .... 00005 595 
Text Processing Package 195 

Lyrix by SCO 595 

SCO Professional 7- - 795 

SCO XENIX-NET oes «= 595 

XENIX System V 386 dy SCO New CALL 

softcraft products 

Btrieve /SAM Mgr with No Royalties .........0045 245 
Xtrieve Query Utility... 6... cc eee eee eee 245 
Report Option for Xtrieve .......-- 2.2. ee eee 145 

Btrieve/N for Networks .....-..0-200ee eee eens 595 
KteevE/M 2 vice sicasic sane nieseesicseninawcee 595 
Report Option/N for Xtrieve/N ... 2... eee e ee 345 

text editors 

Brief & dBrief Combo from Solution Systems ...... 275 
BN cescscusnanmeseuseucesea vere See 195 
Brief Customizes Brief for dBASE Ii! 95 

de by David LIVSHIN. «6.0 e eee cece een eeee 75 

Epsilon Emacs-like editor by Lugaru 195 

KEDIT by Mansfield Software .........-... --- = 125 

Micro/SPF by PHASER SYSTEMS 175 

Microsoft Word ...........-..-++- 450 

PC/VI by Custom Software Systems ..........045 149 

SPF/PC by Command Technology Corp........... CALL 

Vedit Plus by CompuView.......-..--20.eeeeee 185 

turbo pascal utilities 

ALICE /nterpreter by Software Channels .......... 95 

DOS/BIOS & Mouse Tools by Quinn-Curtis........ 75 

Flash-up Windows by Software Bottling .......... 90 

MACH 2 for Turbo Pascal by Micro Help ... a 69 

MetraByte D/A Tools by Quinn-Curtis . . . 100 

Science & Engrg Tools by Quinn-Curtis 75 

Screen Sculptor by Software Bottling . ~ 125 

Speed Screen by Software Bottling..........6..% 35 

System Builder by Royal American .... New Version 150 
IMPEX Query Utility 00. eee ee 100 
Report Builder .............-..- New Version 130 

TDebugPLUS by TurboPower Software ........... 60 

Tmark by Tangent Designs «0.0... .00ccesueeees 80 

Turbo EXTENDER by TurboPower Software ........ 85 

Turbo OPTIMIZER dy TurboPower .............++ 75 
with Source Code .....2..eceeseceveeeeees 125 

Turbo Professional by Sunny Hill .... 2.6... 00 00s 70 

TurboHALO from IMS]... 6. eee eeeeeeeeee 129 

TurboPower Utilities by TurboPower............+ 95 

TurboRef by Gracon Services ......-.+0+e0ee0ee 50 

TURBOsmith Source Debugger by Visual Age ...... 99 

Universal Graphics Library by Quinn-Curtis ........ 130 

wendin products 

Operating System Toolbox ...........-e00ee0es 99 

PCNX Operating system... 26.6. sce e cece cnenee 99 

PCVMS Similar to VAX/VMS «0... e cece eee e ee 99 

Wendin-DOS Multitasking DOS. ..... 6.2. .0.0005 99 

Wendin-DOS Application Developer's Kit ..... New 99 

XTC Text Editor w/Pascal source .............++ 99 

xenix/ unix products 

Btrieve /SAM File Mgr by SoftCraft ..........0005 595 

C-terp by Gimpel, Specify compiler . . 498 

c-tree /SAM Mgr by FairCom ..... 395 

dBx with Library Source by Desktop Ai 550 

DIRECTORY SHELL 286 
by American Mgmt Sys... 0.0.00 e eee ees New 349 

DIRECTORY SHELL 386 
by American Mgmt Sys 0... 0. 0.00000008 New 495 

DOSIX Console Version by Data Basics ........... 400 

DOSIX User Version by Data Basics ........40.45 200 

Micro Focus Products See Micro Focus Section 

Microport Products See Microport Section 

Microsoft Products See Microsoft Section 

PANEL Plus by Roundhill Computer Systems ....... 795 

REAL-TOOLS Binary Version by PLT ..... 1.02000 99 
Library Source Version ....-+.0+00eeeereeeee 599 
Complete Source Version ......++++0+0e0e00% 999 

RM/COBOL by Ayan-McFarland .........20.0005 1250 

RM/FORTRAN by Ayan-McFarland.............. 750 


SCO Products See SCO Section 
Terms are subject to change. 
©1987 Programmers Connection, Inc. 


LOWEST PRICES 
Due to printing lead times, some of our current 
prices may differ from those shown here. Call for 
latest pricing. 

FREE SHIPPING 
Orders within the USA (including Alaska & Hawaii) 
are shipped FREE via UPS. Express shipping is 
available at the shipping carrier's standard rate 
with no rush fees or handling charges. To avoid 
delays when ordering by mail, please call first to 
determine the exact cost of express shipping. 


VISA and MasterCard are accepted at no extra 
cost. Your card is charged when your order is 
shipped. Mail orders please include credit card 
expiration date and authorized signature. 


CODs AND POs 
CODs and Purchase Orders are accepted at no 
extra cost. No personal checks are accepted on 
COD orders. POs with net 30-day terms (with initial 
minimum order of $100) are available to qualified 
US accounts only. 


SALES TAX 
Orders outside of Ohio are not charged state sales 
tax. Ohio customers please add 6% Ohio tax or 
provide proof of tax-exemption. 


INTERNATIONAL ORDERS 

Shipping charges for International and Canadian 
orders are based on the shipping carrier's standard 
rate. Since rates vary between carriers, please call 
or write for the exact cost. International orders 
(except Canada), please include an additional $10 
for export preparation. All payments must be made 
with US funds drawn on a US bank. Please include 
your telephone number when ordering by mail. Due 
to government regulations, we cannot ship to all 
countries. 


VOLUME ORDERS 
Volume orders may qualify for additional discounts. 
Call us for special pricing. 


SOUND ADVICE 
Our knowledgeable technical staff can answer 
technical questions, assist in comparing products 
and send you detailed product information tailored 
to your needs. 
30-DAY GUARANTEE 

Most of our products (excluding books) come with 
a 30-day documentation evaluation period or a 
30-day return guarantee. Please note that some 
manufacturers restrict us from offering guarantees 
on their products. Call for more information. 


MAIL ORDERS 
Please include your telephone number on all mail 
orders. Be sure to specify computer, operating 
system and any applicable compiler or hardware 
interface(s). Send mail orders to: 


Programmer’s Connection 
7249 Whipple Ave. NW 
North Canton, OH 44720 


Se 800-336-1166 


CANADA 800-225-1166 
OHIO & ALASKA (Collect) 216-494-3781 
TELEX 9102406879 
EASYLINK 62806530 
INTERNATIONAL ........ 216-494-3781 


CUSTOMER SERVICE ... 216-494-8899 
Hours: Weekdays 8:30 AM to 8:00 PM EST. 


fully supported remote graphics device. 
The necessary driver to support dumb, 
CGA-compatible terminals is expected in 
a future release. Functions that are avail- 
able at present include dual intensity, cur- 
sor movement and addressing, and full 
support for function keys, the Alt key, and 
the special keypad keys (home, end, page 
up, and so on), among others. 

To set up the operating system for 
multiuser operation, the $SERIAL.SYS 
device driver is used. This specifies the 
port addresses, buffer size, handshaking, 
and other parameters. The manual also 
describes the simple steps required to set 
up a modem as a remote terminal, thus 
supporting remote access to the system. 


Device drivers 

One of MOS’ strengths is its support of 
device drivers. Unlike the situation with 
PC/MS-DOS, device drivers can be 
dynamically added to and removed from 
MOS at any time through the use of 
.ADDEV and .REMDEV commands. This 
simple process eliminates the need for 
shutting down the system and rebooting to 
change the environment, as is often neces- 
sary when running PC/MS-DOS. The 
Software Link supplies several special 


yw Hire a Pro for 
Your New Turbo 4.0 


urn on the power of Turbo PROFESSIONAL 4.0, a library of more 
than 300 state-of-the-art routines optimized for Turbo Pascal 4.0. 
You'll have professional quality programs finished faster and easier. 


Turbo PROFESSIONAL 4.0 includes complete source code, 
comprehensive documentation and demo programs that 
are powerful and useful. The routines include: 


¢ Pop-up resident routines 


drivers including cache, extended memory 
emulator, RAM disk, and NETBIOS driv- 
ers. This last driver allows each of multiple 
partitions to emulate a stand-alone ma- 
chine on a LAN, thus allowing the system 
to run LAN software or intertask commu- 
nication with file and record locking. Of 
course, the dynamic allocation and deallo- 
cation of device drivers will operate nicely 
with any driver, not just those that The 
Software Link provides. This capability is 
a big plus. 


General Commands 

MOS is designed from the ground up as a 
complete replacement for PC/MS-DOS. It 
capitalizes on the user’s knowledge of the 
latter by employing familiar command 
names and syntax. There are two basic 
command groups, intrinsic and extrinsic. 
The former are resident in $$SHELL.SYS 
and are always available in memory. Ex- 
amples are DIR, ERASE, MD, CD, and so 
on, while the latter include FORMAT, 
DISKID, FILEMODE, and so on. The 
HDSETUP command replaces FDISK and 
allows an active partition larger than PC/ 
MS-DOS’ 32-Mbyte limit. The downside, 
of course, is that PC/MS-DOS will no 
longer operate correctly on such a partition. 


BCD arithmetic 

¢ Virtual windows and menus 

¢ EMS and extended memory access 
¢ Long strings, large arrays, macros, 
and much more. 


Turbo PROFESSIONAL is only $99. 


Call toll free for credit card orders. 


1-800-538-8157 extension 830 
1-800-672-3470 extension 830 in CA 


Satisfaction Guaranteed or your money back within 30 days. 


LUR3e 


TurboPower Software 3109 Scotts Valley Dr., Suite 122 Scotts Valley, CA 95066 


Turbo Pascal 4.0 is required. Registered 
owners of Turbo Professional by Sunny 
Hill Software may upgrade for $30. 
Include your serial number. 


For other information call 408-438-8608, 
9 AM to 5 PM PST. Shipping & taxes 
prepaid for US and Canadian customers, 
others please add $6 per item. 
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Rather than listing every MOS command 
and its corresponding PC/MS-DOS com- 
mand, let it suffice to say that MOS offers 
all that PC/MS-DOS has and then some. 
There are both an editor (sporting line- and 
screen-oriented modes) and a debugger. 
DEBUG has some enhancements over PC/ 
MS-DOS’ debugger. For example, a SWAP 
command allows the screen to alternately 
display the actual program and the 
debugger. In addition, you can use a termi- 
nal for DEBUG while running the applica- 
tion on the main console. 


The BATCH Command 

Once again, MOS builds on PC/MS-DOS 
by enhancing the batch processor. 
BATCH allows nesting of batch files. 
There is a command that permits chang- 
ing directories within a batch file and re- 
turning to the original directory. There are 
also CALL/RETURN, FOR IN DO, GO- 
TO, and IF constructs. This is not an ex- 
haustive list, but it serves to illustrate the 
power of the batch processor. 


Compatibility 

The Software Link explains that MOS is 
designed to run most applications that 
were written to execute under PC/MS- 
DOS in the 8086 mode. The operating sys- 
tem is said to fully support the mono- 
chrome mode at all terminals, and CGA 
on both the main console and at remote 
CGA terminals (as previously mentioned, 
the latter is possible in theory but pres- 
ently is supported only through the use of 
remote computers and an add-on pack- 
age). EGA is supported on the main con- 
sole only. 

Unfortunately, The Software Link says 
very little about the issue of compatibility 
with PC/MS-DOS applications. In order 
to get a feel for compatibility, a shotgun 
approach was used, running numerous 
applications. In every case, text-mode 
applications (WordStar, Supercale 4, 
dBASE III, Microsoft Word in character 
mode, and so on) operated flawlessly. It 
was a simple matter to run several of these 
applications simultaneously in several 
partitions. 

Several communications programs were 
also tried, since the power to perform 
xmodem file transfers in the background 
while doing other tasks in the foreground 
is extremely useful. Procomm, Qmodem, 
and Pro-YAM offered no problems. 

Graphics applications were a different 
story, however. The hardware configura- 
tion for testing includes a Tseng EVA/480 
display board, which may be among the 
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Motorola MC680x0 


National 


Atari's 


GEM-DOS __(w/wo 68881) _ Semiconductor 2 
Apollo, Sun, SGl.... NS320xx 
System 
V.x 
BSD 4.x BSD 4.x 
80(,1,2,3)86 Syste 
80(,2,3)87 
Weitek 1167 V.x BSD 4.x D fe C 
PC AT, PS/2 ULTRIX 
Coenen, XENIX V AX 
' Compatibles 
Le 
PC/MS-DOS 
os/2 BSD 4.x 
FlexOS 


PC-MOS Resident, 
DOS|Extender IBM Embedded, | BM 


OS/286, OS/386 
X-AM (VM/RUN) RT PC and Cross 3/70 
We cut our teeth on UNIX, but have become famous on MS-DOS, which we enhanced with our UNIX-like DOS 


Helper ™ utilities: find (including tar), fgrep, cat, Is, mv, tail, uniq, and we; and our superior optimizing compilers: 


Professional Pascal ™ and High C ™ on the PC are now well-respected by organizations such as Ansa, Ashton-Tate, 
AutoDesk, Boeing (BCS), Daisy Systems Corp., Deloitte Haskins & Sells, Digital Research, GE, IBM, Lifetree, 
Migent, Multimate, NYU, Silvar-Lisco, Sky Computers, Symantec, Xerox/Ventura, ...and Computer Language 
magazine; Dr. Dobbs’ Journal; PC Tech Journal; PC Magazine; and the Journal of Pascal, Ada, and Modula-2. 


We supplied the first compilers generating 32-bit protected-mode code for the 80386 under MS-DOS (since 11/ 
86). And our newly upgraded MS-DOS real-mode compilers were used by Symantec for their Q&A™ product to 
exploit the power of the 80386 real-mode instruction set. (HC v1.4 and PP v2.7 released May 1987.) 


Our C Validation Suite will blow your C compiler out of the sea, while our C compiler tracks the emerging ANSI 
Standard and generates tighter code with far better lint-like feedback help than competing compilers. 


And you’ll love Professional Pascal’s Ada-like packages, true data abstraction, C-like bit manipulation, and much 
more, along with the tight code that is linkable with High C, or other C, object modules (and vice versa). 


Our Translator Writing System (TWS) goes far beyond LEX and YACC, with fully automatic error recovery... 
All uniformly implemented on UNIX, VMS, CMS, MS-DOS, FlexOS, ... 


Professional developers in need of industrial-strength tools contact: 
MetaWare Incorporated 


poli leee Tere) 
Wats AN, Use (408) 429-6382 


INCORPORATED Telex: 493-0879 (META Ul) 
PC Tech Journal's conclusion: 


The Clear Choice for Large Programming Projects. 


Name ee _~—s- MS: 1187 Circle what interests you: 

Company Product: PP HC TWS _ Helper (DOS only) 
Address Platform: V.x 4.x DOS FlexOS VMS CMS 
City, ST Zip Sun Apollo Atari VAX 370 

Phone ( ) 8086-family 80386 680x0 32032 


© 1987 MetaWare Incorporated. MetaWare, High C, Professional Pascal, and DOS Helper are trademarks of MetaWare Incorporated. Others/ owners: Ada/DoD; 
Apollo/Apollo; Atari/Atari; DEC,VAX,VMS/DEC; FlexOS,GEM-DOS/DRI; IBM,RT PC/IBM; MS-DOS/Microsoft; Q&A/Symantec; Sun/Sun Microsystems; UNIX/AT&T. 


Footnotes: 1. Atari, CMS versions available 10/87. 2. NS320xx version by special order. 3. UNIX not yet available on 370. 


best of the breed of hybrid video boards, 
supporting monochrome text, EGA, and 
CGA applications virtually seamlessly un- 
der PC/MS-DOS. MOS was another 
story. For example, Ventura Desktop Pub- 
lisher could be loaded and executed except 
that the lower half of the EGA screen was 
obliterated by a solid pattern. Autocad’s 
menus were fine, but when the system was 
instructed to draw a screen, it did not dis- 
play. Similarly, Microsoft Word, in its de- 
fault graphics mode, crashed the system. 
During consultation with the MOS techni- 
cal support people, they verified that cor- 


rect operation of EGA applications is cur- 
rently a problem, but added it is a high 
priority for the next release. 

The package comes with a notice that 
all users of the first release (1.01) will be 
upgraded to the next version some time in 
the next several months, free of charge. 
Hopefully, this is, indeed, one of the areas 
that will receive attention in the next re- 
lease. A pure EGA-only card might have 
been more successful, and a CGA- 
equipped machine would have certainly 
operated correctly with graphics 
applications. 


TASKVIEW 


ROCK SOLID 
MULTITASKING! 


Packed with the power you need, TASKVIEW takes you beyond 


the limits of DOS. 


® Communicate while you edit 

® Compile while you print 

® Load up to 5 megabytes of programs 

@ Manage resident utilities 

® Time-slice multiple jobs 

= Cut & paste between programs 
TASKVIEW lets you load up to 10 of your favorite applications and 
switch between them at a keystroke. They can even continue to 
run while you work on something else! TASKVIEW is the BEST 
multitasker you can buy. Just ask our customers. 


“Thanks for a wonderful product!”’ 

“TASKVIEW is the only multitasker | own which runs efficiently & 
correctly both on my Zenith Z-151... and on my Orchid 286e.. . I 

also have DoubleDOS, DESQview, TopView, Windows, and Concur- 


rent PC-DOS”’. 


‘Fantastic! What DoubleDOS, MS-Windows, and all the other ‘stuff’ 


should have been!”’ 


‘‘My BBS is now up 24 hours, 7 days a week thanks to TASKVIEW.”’ 


‘Thanks! I needed that!”’ 


TASKVIEW requires an IBM PC, XT, AT or Jr compatible, and PC 
or MS DOS 2.x to 3.x. To get your copy, call toll free: 

(800) 367-0651 
or send $79.95 + $3.00 S&H ($8.00 Intl.) to: 


® 
@ Sunny Hill Software 
PO Box 55278, Seattle, WA 98155-5278 
For more information call (206) 367-0650 


DoubleDOS trademark Softlogic Solutions, Concurrent PC-DOS reg. trademark Digital Research Corp.. MS Windows 
trademark Microsoft Corp.. DESQview trademark Quarterdeck Office Systems, Inc. TopView trademark IBM Corp 
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In summary, MOS does not get a strong 
positive vote as far as compatibility with 
graphics applications that do work sat- 
isfactorily under PC/MS-DOS, but The 
Software Link will probably address this 
area in the next version. 


Performance 

I ran several benchmarks (Norton, MIPS, 
and Version 4 of the PC Magazine bench- 
marks) under MOS and compared them to 
results under PC/MS-DOS. In every case, 
results were identical. Of course, these tests 
were conducted with only one MOS parti- 
tion active. The tests show that there is no 
unusual overhead encountered under MOS. 


Summary 
PC-MOS/386 is an ambitious effort on 
the part of a small firm to leapfrog over 
Microsoft and offer a protected environ- 
ment operating system on the 80386. And 
the effort has succeeded while maximizing 
compatibility with existing applications. 
Some kinks remain in the handling of 
graphics applications and there are a few 
minor-bugs in some of the commands, but 
in general, MOS is a successful alternative 
to waiting for OS/2. Multitasking and 
multiuser operation on a 386 is a reality. 
MOS’ pricing is also attractive, with the 
single-user version at $195, the five-user 
version $595, and the twenty-five-user ver- 
sion $995, And discounted products are al- 
ready appearing in the marketplace. MOS 
certainly bears serious investigation by all 
PC/MS-DOS users with 80386 systems. § 


Charles Strom is Director of Labora- 
tories and Director of Technical Services 
manager of the Department of Chemistry 
for New York University and is actively 
involved with microcomputer facilities 
development at the university. He is also 
the PC sysop on the GEnie national time- 
sharing service. 


Product Information 
PC/MOS-386 Operating System 
$195 (single user) 

$595 (five user) 

$995 (twenty-five user) 


The Software Link 

3577 Parkway Lane 

Atlanta, GA 30092 

(800) 451-5465 

(800) 387-0453 (Canada) 

(404) 448-5465 (GA) 

(404) 263-1006 (OEM/Int’l sales) 
(404) 448-5465 (Reseller/VAR sales) 
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Nedar C. fofom » f J, MaAali> ’ ey M4 
Order Eco-C88 Rel. 4.0 New Modeling Compiler 
f 


. | wa ot wt» h, = », 
and get C-more at no extra charge! 


Seek and Correct 
You already know that fast compilation does not mean fast program development. Backing 
up for bogus error messages and removing the bugs takes time. Eco-C88’s “Seek and Correct” 


three - way error checking finds even the most elusive bugs, clearing the path for swift program 
development. 


Double Barrel Error Checking 
Eco-C88 nails syntax errors cold and tells you about the error in plain 
English. And there's no avalanche of false error messages, either. Other 
compilers can generate up to four times the number of error messages 
actually present; they leave it up to you to guess which ones are 
real. You'll be more productive with Eco-C88 because there is no 
guess work. 


Eco-C88 provides ten levels of semantic error checking. You can 
select from almost no checking to the fussiest you've ever seen. 
Eco-C88’s “picky flag” finds subtle errors that slip by 
other compilers. 


c £22 =) , 
£CO-CS6 also features: 


© All data types, plus ANSI Enhancements 
@ Robust library, including many new ANSI Memory Options 
functions 


© CED editor with online function help, split y 
windows, compile-edit-link capability f Se eae 
© New, expanded manual with sample pro- Model Code Size Data Size 


grams for the library functions Small 64K 64K 


e Compact 64K 1 Meg 
C-more Source Cod 
C-more Source Code Medium 1 Meg 64K 


Debugger 


Finally, if a really nasty bug persists, 
put C-more, our source code debug- 
ger, to work. With C-more you can 
watch your program as it executes, 
single-step it, set simple or conditional 
breakpoints, test complex expressions, 
use variables as indexes into other vari- 
ables, initialize and trace variables, examine 
CPU registers, display results with printf()- 
type options and much more. C-more can help * 
you track down bugs in minutes rather than days. 


Large 


The price for Eco-C88 is $99.95. And, for a 
limited time, we’ll give you our C-more debugger 
at no extra charge. 


Ecosoft Inc. 
6413 N. College Ave. 
Indianapolis, IN 46220 


(317) 255-6476 (Tech Info) 
(800) 952-0472 (Orders) 
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- Hardware Review 


Intel’s 


ISBC 386AT 


A lot of people (myself included) were sur- 
prised at the speed with which the mail- 
order clone companies began offering 32- 
bit 80386 systems. Behind the surprise 
was the fact that Intel had quietly begun 
shipping OEM quantities of its iSBC 
386AT motherboard. The iSBC 386AT, 
installed in an AT-clone cabinet, allows a 
highly IBM compatible 386 machine to be 
assembled with virtually no engineering. 
Many mail-order 386 compatibles incor- 
porate the board, which is also available 
via some Intel distributors. 


Overview 

The iSBC 386AT has the same physical 
dimensions as the IBM PC/AT mother- 
board. It can thus be installed in any case 
designed for IBM PC/AT or compatible 
motherboards. The iSBC 386AT has 
512K X 8 of socketed RAM that runs 
with effectively one wait state at both the 
16-MHz and 6-MHz processor clock rates. 
It contains eight expansion slots: two 8-bit 
PC-compatible slots, four 16-bit AT-com- 
patible slots, and two 32-bit slots of Intel’s 
own design (and used nowhere else to my 
knowledge). The 32-bit slots will accept 8- 
bit cards but are keyed to prevent insertion 
of 16-bit cards. While the 32-bit slots op- 
erate at the full 16-MHz clock rate, the 8- 
and 16-bit slots operate at 8 MHz. Up to 
16 Mbytes of RAM may be installed on 
the bus. The AT-compatible ROM BIOS is 
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by Jeff Duntemann 


from Phoenix Technologies. 

An AT-compatible keyboard may be 
plugged into the DIN-style keyboard con- 
nector. A CMOS battery-operated real- 
time clock chip also contains 50 bytes of 
nonvolatile RAM to hold setup informa- 
tion during power-down periods. Unlike 
the IBM PC/AT, there are RS232C serial 
and Centronics-compatible parallel ports 
on the board. 


Memory Architecture 

Over the past year or two, the speed of 
processors has begun outrunning memory 
systems. The absurdity of cranking up a 
4.77-MHz PC to 9.54 MHz and then 
throttling the effective clock speed back to 
6 MHz by adding wait states is only now 
being recognized. The key to machine per- 
formance is not CPU speed but memory 
architecture and access time. 

IBM’s PC/XT-286 appears to operate 
much more quickly than its 6-MHz 80286 
processor would suggest because it is run- 
ning its memory system without wait 
states. Both the 6-MHz and 8-MHz PC/ 
AT’s run with one wait state, and most 
turbo boards without on-board memory 
that are sold for the 8-bit PC/XT bus add 
two or more wait states to allow the fast 
CPU to work with the much slower XT bus 
and memory. 

A wait state is simply an extra bus ac- 
cess cycle requested of the CPU by exter- 


nal hardware. This extra cycle merely pro- 
vides a pause while the memory system (or 
some other system running more slowly 
than the CPU) does what it must and 
catches up to the CPU. 

The relationship between clock speed 
and wait states is not a simple one. In or- 
der to operate at 16 MHz with zero or one 
wait state, the 80386 would require very 
fast DRAM in the 50-60 ns range. DRAM 


chips with access times of less than 100 ns 
are still premium parts and very expensive 
by microcomputer standards. 

To keep the price of the memory system 
down, more cleverness is required of the 
memory system. The iSBC 386AT’s mem- 
ory system takes advantage of the reason 
why wait states are necessary to begin 
with: DRAM refresh. Once you read data 
from a DRAM, you must allow a period of 
time to pass before reading it again to re- 
fresh it at least once between reads. 

The iSBC 386AT memory system is 
split into two banks, and successive 32-bit 


(4-byte) blocks of memory alternate be- 
tween the two banks. In other words, Bank 
A contains memory locations 0-3, Bank B 
contains memory locations 4-7, Bank A 
contains memory locations 8-11, Bank B 
contains memory locations 12-15, and so 
on, with every other 32-bit block of mem- 
ory belonging to every other memory 
bank. Since the 80386 fetches memory 
from the bus 32 bits at a time, successive 
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FOR YOUR PC 


20,000 FILES 


— AS CLOSE AS YOUR MODEM — 
BBS 414-964-5160 


Exec-PC, the country’s largest electronic Bulletin Board System (BBS), has the most 
extensive online collection of software available anywhere. Yours for the asking. 


What the magazines say: “... The biggest, meanest, most oft-dialed and 
technologically audacious BBS this side of Silicon Gulch.” 

Milwaukee Magazine, June 1987. 

“Exec-PC, the bulletin board answer to SuperStation WTBS, connects 

PC users continents apart. The big board caters to business PC users, 

many of whom treat it ‘as a dirt-cheap [PC] consulting service,’ accord- 

ing to system operator Bob Mahoney. ‘Some of the foremost experts in 

the country call this system,’ he says. Exec-PC’s storehouse includes 

20,000 public domain programs, ten conference areas ranging from CAD 

to hardware acceleration, and some of the slickest conferencing and 
electronic mail (E-mail) software to scroll across a screen.” 

Reprinted by permission of PC World, 501 2nd St. Suite 600, 

San Francisco, CA 94107, Vol. 5 issue 7, July 1987 p. 72 

(Note: We now have 20 conference areas.) 


WHAT YOU COULD HAVE 

Would you like public domain and shareware word processor programs, 
communications programs, or excellent database management systems? 
How about personal money managers, or General Ledger programs? If 
that is not enough, look at the 1000 games and 7500 free business 
oriented programs, utilities, tutorials, and reviews. This gives you every- 
thing from hard disk reorganization and backup to stock market man- 
agement systems. We also maintain the entire PC-SIG collection online, 
the 800+ diskette collection of public domain software from California. 


WHO HAS IT? 

Exec-PC owns and operates the nation’s largest electronic Bulletin Board 
System. Through our BBS, our huge software collection is available to 
anyone who has access to a modem and a telephone line. We have more 
than 20,000 individual files available for immediate download to your 
computer, 24 hours a day, every day. 


WHAT IT IS 

The BBS consists of a large computer with BIG disk drives (more than 1 
gigabyte!) and many phone lines connected to it. The computer currently 
has 32 phone lines, allowing it to talk to 32 callers at once. It receives 
about 700 calls per day. Using the BBS is easy, since it is menu driven and 
you simply choose what you want to do. 


WE SURE HAVE FILES 

A typical user will call the BBS, ask the BBS to show what files are new 
since his or her last call, find files of interest, then transmit those files 
across the phone line. After hanging up, the caller can examine and use 
the new software. 


WE SURE DO TALK 

Our BBS also has an active conference system where hundreds of people 
share ideas and solutions. Some conferences include: PC General Topics, 
Communications, For Sale, Programming, Desktop Publishing, LAN, 
Graphics, Hardware Speedup, PCjr, CAD/CAM, Private e-mail, etc. Why 
pay expensive consultants when there are hundreds of experts available 
in our forums and conferences? 


HOW DO I ACCESS THE SYSTEM? 

The Exec-PC BBS is available through either direct dial-up, or through a 
new service called Telenet PC Pursuit. Long distance callers enjoy PC 
Pursuit because it allows unlimited long distance calling for $25 per 
month. The PC Pursuit service is offered by GTE/Telenet. Contact them 
at 1-800-835-3638. 


HOW TC CALL THE EXEC-PC BBS 

1. Set your asynchronous modem for any speed up to 2400 baud. 

2. Start up your communications program. 

3. Dial 414-964-5160. 

4. Hit a few carriage returns to tell the BBS you are there. 

The BBS will ask for your name, then you will be guided into the menus. 


IT IS FREE, BUT 

You can call the BBS at any time without registering. You can tour the 
system, read messages, and download some of our files. For greater 
access privileges you may register at the following rates: $15 for 3 months 
or $45 for one year. You may subscribe online with VISA or MC, or by 
credit card, check or money order with the form below. Paid registration 
allows one hour of full access per day. 

Exec-PC, Inc. 


P.O. Box 11268 Shorewood, WI 53211 
Voice Orders 414-242-2173 BBS 414-964-5160 


BBS 414-964-5160 


TO: Exec-PC, Inc. @ P.O. Box 11268 ® Shorewood, WI 53211 


YES! Register me on the Exec-PC BBS for full access to the 
country’s largest collection of PC software plus thousands of 
informative messages and conferences. 


01 Year $45 
— O 3 Months $15 
U Check Enclosed 0 Visa 
Credit Card Account # 
—— 


CO MasterCard 


Expires 


Name 

Company (optional) 
Street 

City 

Telephone ( ) 


State Zip 


Name you will use for Logon to BBS (required) 


First Last 


Four Character Password 


memory accesses will alternate banks. 
This allows the 386 to read 32 bits from 
Bank A, and then immediately read an- 
other 32 bits from Bank B, because while 
Bank B is being accessed, Bank A can be 
refreshed. When it is time for the third 
access to be made, Bank A has been re- 
freshed and is ready to be accessed. 

This alternate-bank system allows the 
use of 120 ns DRAM at 16 MHz with only 
one wait state. The DRAM chips are 
64K X 4, with each bank arranged as 
256K X 8. This setup is the reason why 
there is only 512K and not 640K DRAM 
on the board. The alternate-bank system 
requires two identical banks of DRAM, 
but there is no convenient way to create 
two 320K banks of DRAM without cover- 
ing the motherboard with 64K chip sock- 
ets. This is a serious problem, as I will de- 
scribe in more detail below. 

The 80386 CPU contains another trick 
called address pipelining, which essen- 
tially puts the next address out on the bus 
while data at the current address is still 
being fetched. Address pipelining allows 
the slower memory system to get a head 
start on the next memory read if the next 
read is in the alternate or nonbusy mem- 
ory bank. 

The downside of this memory system 
trickery is that it is not possible to flatly 
state that the memory system runs with 
one or two or any number of wait states. 
Normal code tends not to be consistent in 
accessing memory neatly in alternate 32- 
bit chunks, and successive accesses to the 
same bank trigger a three-wait-state pen- 
alty. For example, the 80386’s prefetch 
queue, when active, always reads 32-bit 
blocks from alternating memory banks. If 
a register-intensive code sequence is run- 
ning and the 80386’s prefetch queue is 
constantly in use, the system will run with 
one wait state. However, as soon as the 
prefetch queue must be purged (for exam- 
ple, if a jump instruction is executed) the 
situation becomes much more compli- 
cated. Remarkably, the repeating string 
instructions set off a veritable explosion of 
wait states, especially the STOSB and 
MOVSSB instructions that write sequential 
data 1 byte at a time, because they write 
four times in succession within a single 
memory bank. In practice, the number of 
wait states on the bus depends heavily on 
the nature of the code being executed, but 
the chances of incurring a wait-state pen- 
alty above the normal one wait state are 
about 50 percent. 

The iSBC 386-AT contains two 32-bit 
expansion slots of Intel’s own design. 


Table 1. Performance Tests 

Peter Norton’s SI Utility rates the iSBC 386AT at 18.7. The best single-value benchmark, 
however, is Landmark Software’s SPEED which takes memory system performance into 
account, and which rates the iSBC 386AT at 15.6, a rough equivalent to the IBM PC/AT 
running at 15.6 MHz. 


A PERFORMANCE SUMMARY 


Landmark 
SPEED 
Peter Norton's SI Utility 


15.6 MHz AT equivalent 
8.3 times PC/XT performance 
18.7 


PC Labs’ benchmarks below substantiate my own findings with regard to memory /memory 
compilation performance. (I compiled a 740-line Turbo Pascal source file for a “‘whereis” 
utility in 7.4 seconds going from memory to memory on a PC, and in 1.8 seconds on the iSBC 
386AT.) 


SPEED INDEX 
RELATIVE TO 
4.77 MHz PC 


SPEED INDEX 
RELATIVE TO 
8.0 MHz AT 


TIME IN 
SECONDS 


1. 128K NOP loop 
. Do-nothing loop 
. Integer add loop 


. Integer multiply loop 
String sort and sort 


. Prime number sieve 


2 
3. 
4 
5, 
6 
7. 8086/8088 instruction set 


Chips & Technologies MIPS seems to indicate that the iSBC 386AT has the same speed as 
an 8-MHz IBM AT, which simply isn’t the case. In general, benchmark tests are poor 
substitutes for loading real applications. My favorite is Microsoft Windows, which runs 
faster on the iSBC 386AT than on anything without a 386. 


IBM XT 
4.77 MHz 


IBM AT 
8.0 MHz 


COMPAQ 
386 


INTEL 
386 AT 


1. General instructions 


2. Integer instructions 2.19 0.96 2.35 
3. Memory to memory 5.48 1.69 0.94 1.30 
4. Register to register 17.81 2.31 0.97 3.20 
5. Register to memory 5.68 1.71 0.94 1.75 


6. Performance rating 
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These slots are actually expansions of the 
PC/XT-style 8-bit bus rather than the 
PC/AT’s. 16-bit bus. Eight-bit expansion 
boards may be plugged into the forward 
portion of a 32-bit slot, but, as noted ear- 
lier, the slot is keyed to prevent insertion of 
a 16-bit board. 

The 32-bit extension is little more than 
the 80386’s 32-bit addressing machinery 
brought from the CPU chip to the bus. The 
32-bit slots are obviously intended for 
memory boards rather than other periph- 
erals, which stand to gain little from being 
redesigned as 32-bit devices. Intel sells a 2- 
Mbyte, one-wait-state memory board for 
these slots, and very recently Fortron Cor- 
poration has begun offering a similar 2- 
Mbyte board for the Intel 32-bit bus. This 
latter allows up to 4 Mbytes of 32-bit 
RAM, using currently available expansion 
boards. Intel has announced but has not 
yet shipped an 8-Mbyte, 32-bit RAM 
board for the 32-bit bus. These boards of- 
fer the same alternate-bank structure and 
address pipelining features used on the 
motherboard, and are otherwise similar 
except that they are extended memory 
rather than real-mode memory and cannot 
be mapped into the lower 640K. 

This leads us to the single largest defect 
of the iSBC 386AT design: There is no 
way to install true 32-bit RAM between 
the 512K and 640K boundaries. The 
motherboard sockets cannot be reconfig- 
ured for other types of chips, and the 32- 
bit boards can be used only as extended 
RAM past | Mbyte. The only way to make 
the board into a 640K system is to fill the 
missing 128K with a 16-bit expansion 
board in one of the 16-bit slots. A number 
of 128K short-slot memory boards were 
designed to fill out the original PC/AT’s 
512K RAM system to 640K (the name 
TophAT comes to mind), and these will 
work here. 

The problem is that the 80386 is really 
designed for 32-bit memory fetches, and 
16-bit boards can only output one 16-bit 
word, rather than one 32-bit word per ac- 
cess. It thus takes the 386 at least twice as 
long to read the same number of bytes 
from 16-bit RAM. And if that were not 
problem enough, the iSBC 386AT oper- 
ates its 8- and 16-bit slots at an effective 
clock rate of 8 MHz to allow full hardware 
compatibility with boards designed for the 
standard PC/AT. Finally, neither alter- 
nate-banking nor address pipelining work 
for 16-bit memory. Accesses to 16-bit 
memory installed on the bus can take as 
much as five times as long as comparable 
accesses to true 32-bit memory. 
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The memory organization of PC-DOS 
Version 3 aggravates the situation further 
from an operational standpoint. DOS and 
RAM-resident utilities are loaded into low- 
memory, below transient applications. The 
more resident utilities you load, the higher 
into memory your transient programs get 
bumped. Ultimately, the lion’s share of 
your fast 32-bit RAM is taken up by DOS 
and resident programs that execute only 
rarely, while the bulk of executing code in 
your transient application may venture 
above 512K and slow the effective speed of 
the machine to a relative crawl. 

From a memory perspective, the iSBC 
386AT would be best applied as a 386 na- 
tive mode machine, running native mode 
applications in memory above | Mbyte. 
As native mode operating systems for the 
386 are quite new and as yet unproven, 
little software is available for them, and 
this promise must, for now, go unfulfilled. 


Math Coprocessor Module 

The iSBC 386AT contains a socket for the 
80387 math coprocessor. The 80387 is the 
80386’s partner in floating-point math, 
and is only now becoming available. To fill 
the gap, Intel has been offering SBCMath, 
a small daughterboard that plugs into the 
80387’s pin grid array (PGA) socket. 
SBCMath contains a 10-MHz 80287 co- 
processor, with glue logic to make the 287 
electrically equivalent to a 387. Intel says 
little about the SBCMath module other 
than that it operates at 10 MHz, asynchro- 
nously to the CPU. The company also does 
not promise that the daughterboard’s per- 
formance will be equivalent to that of a 
real 387. The boost in calculation speed is 
significant, however, when 8087/287/387 
knowledgeable code is run on the board. 
No 80387 was available for comparison, 
but SBCMath was tested in conjunction 
with this review. 

Intel has disclosed a compatibility prob- 
lem between the 387 and 386 on early pro- 
duction motherboards. The affected 
boards carry the number 149422-0XX or 
137406-OXX. These boards, however, do 
work with the SBCMath 80287 copro- 
cessor module. 


Setup and Configuration 

The iSBC 386AT’s electrical design is not 
impressive. The lack of custom LSI means 
that the board is tightly packed with ordi- 
nary DIP devices, and a truly appalling 
number of jumper wires was used on all of 
the boards I examined. Worst of all, no 
DIP switches are used to facilitate hard- 
ware configuration. Instead, no fewer than 


14 separate header pin groups are scat- 
tered across the board, and default con- 
figurations are set by jumpering the pins 
with shorting blocks. 

The jumpers specify things such as the 
power-up default monitor type, enable/ 
disable keyboard reset, the enable/disable 
serial and parallel ports, the number and 
type of extended RAM boards, serial port 
IRQ number, and coprocessor presence or 
absence. Although most of these condi- 
tions will change only rarely, some of them 
(such as the default monitor type) change 
often enough to make locating and chang- 
ing the shorting blocks an intrusive nui- 
sance. Furthermore, some of the header 
pin groups are located beneath the mass of 
cables running to the disk drives and are 
difficult to change without pulling the ma- 
chine completely apart. 

Once the power-up default conditions 
are set with the shorting blocks, however, 
setup of other system parameters is done 
AT-style, using a SETUP utility provided 
with the iSBC 386AT. SETUP allows the 
battery-sustained clock/calendar chip, the 
diskette drive number and types, the fixed 
disk number and types, the base and ex- 
pansion memory, and the installed display 
adapter to be set. SETUP understands an 
impressive 47 different fixed disk drives, 
with capacities up to 127 Mbytes. The list 
is large, but no facility is included for en- 
tering specs for a drive type that is not yet 
part of the list. If you have an unlisted 
drive, it may run poorly or not at all if you 
install it as a drive with close but not iden- 
tical specs. 

The Phoenix ROM BIOS supports the 
peculiarly named deturbo mode, an effec- 
tive 6-MHz slowdown of the system clock 
that is included to accommodate sensitive 
copy-protection schemes. Effective clock 
speed may be toggled between 6 and 16 
MHz with the Ctrl-Alt-1 (keypad) and 
Ctrl-Alt-2 (keypad). Again, these hot key 
codes are fixed in ROM and cannot be 
changed. The speed may also be changed 
under program control by outputting a 
control value to I/O port 64h. 


Software Compatibility 

The iSBC 386AT is extremely IBM com- 
patible from a software perspective. The 
failures I observed were universally due to 
copy-protection schemes. Most schemes 
that failed at 16 MHz passed when the 
board was throttled down to 6 MHz. The 
exceptions were boot-only games, since 
the boot operation must always occur at 
16 MHz. Interestingly, one boot-only 
game that booted at 16 MHz ran in the 
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same way at 16 MHz as at 4.77 MHz: 
Gerald Kuperberg’s venerable J-Bird. 
Kuperberg is apparently one of the few 
game designers clever enough to design 
CPU speed out of his code. 

The list of business and software devel- 
opment products that I ran successfully on 
this machine over a six-month period is 
long indeed, and the following is only a 
part: all Borland products, Microsoft 
Windows, C, Pascal, Quick BASIC, GEM, 
Ventura Publisher, In-A-Vision, Lotus 
1-2-3, Framework II, Crosstalk XVI, 
Word Perfect, Wordstar, Paradox, 
Smalltalk V, Personal TgX, Logitech 
Modula 2, and Halo DPE. In general, my 
experience would imply that any non- 
copy-protected PC-DOS business applica- 
tion that will run on an 8-MHz AT will run 
on the iSBC 386AT. Games and very low 
level developer’s tools might not. 

Quarterdeck Office Systems’ DESQ- 
view, in its latest release, offers support of 
the 80386’s virtual 86 mode, and allows as 
many DOS partitions as memory will sup- 
port, with very effective text windowing. 
DESQview installed easily and ran with- 
out incident. 

Far more interesting, if somewhat more 
sensitive, is the Software Link’s PC MOS/ 
386, a true native mode 386 operating sys- 
tem that does not require DOS to be 
present. Rather, it replaces DOS with a 
native code 386 operating system that 
shares a compatible API with PC-DOS 
3.1. PC MOS introduces a speed penalty 
somewhat like that of Xenix: noticeable 
but not crippling. This is to be expected, 
since the copy I tested supports up to five 
users and any reasonable number of tasks. 

PC MOS/386 took some tinkering to in- 
stall, but once installed it ran fairly well. 
Now and then, however, the system simply 
“went away,” implying that the product 
has not yet reached maturity. 


Hardware Compatibility 

Hardware compatibility is a more difficult 
test to pass, since board products are more 
timing sensitive than software. Even with 
a bus that operates at an equivalent clock 
speed of 8 MHz, 386 timing is different 
enough to cause problems. The Periscope 
Submarine board and Tall Tree Systems’ 
JLaser both caused problems that the ven- 
dors admitted were unavoidable in current 
releases. 

Board products that ran without inci- 
dent included the Bernoulli Box 10 x 10 
controller, Microsoft and Logitech Mouse 
bus cards, Paradise Autoswitch EGA, 
MDS Genius VHR video controller, IBM’s 
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Game Control Adapter, Tecmar’s Graph- 
ics Master, D.C. Hayes’ 1200B internal 
modem, and a number of “generic” clone 
boards containing extended RAM and se- 
rial or parallel ports. Several AT-style disk 
controllers also worked well. Peripherals 
such as printers, plotters, modems, and 
mice that operate through standard serial 
and parallel ports should work without dif- 
ficulty. Table 1 summarizes all the per- 
formance tests. 


Conclusion 

The iSBC 386AT advantages are that it is 
fast and can run Aypervisors like DESQ- 
view that allow you to turn ordinary appli- 
cations into resident applications by 
putting each in its own virtual 86 partition. 
True native mode reliable multiuser op- 
erating systems such as PC MOS/386, 
Concurrent DOS-386, and Xenix are now 
available for the 386, and if you need 
multiuser ability, the iSBC 386AT is a 
contender. 

As a real-mode superfast AT-compati- 
ble, however, the board has an extremely 
serious shortcoming: It can contain only 
512K of fast 32-bit RAM. If you need 
640K, you will bleed away the greater part 
of the CPU’s speed advantage in a torrent 
of wait states and inefficient 16-bit mem- 
ory accesses every time code is executed 
above 512K. 

Also, the 32-bit extended memory 
boards are expensive and hard to find. 
Intel offers a 2-Mbyte extended memory 
board and has promised an 8-Mbyte 
board, but has made no effort to market 
the memory boards widely. At the Spring 
Comdex Exposition, Fortron Corporation 
was showing a $700 2-Mbyte board for 
the Intel 32-bit bus, but it was not avail- 
able in time to be evaluated here. 

Minor problems, such as jumper blocks 
all over the board, imply that the board was 
never really intended to become a mass- 
market product. Rather, it resembles more 
strongly the engineering evaluation boards 
from microprocessor companies. 

Better 80386-based motherboards will 
soon be available (for example, the ALR 
386/2 and ZEOS International units) 
based on the Chips & Technologies’ 386 
AT Chipset. At its current street price of 
$2000, the iSBC 386AT is no longer espe- 
cially competitive. § 


Jeff Duntemann has written about the 
microcomputer industry since 1977. He is 
the author of Complete Turbo Pascal and 
Turbo Pascal Solutions, and is Editor in 
Chief of Turbo Technix Magazine. 


Where to Buy the Intel 
iSBC 386AT Board 
The Intel iSBC 386AT motherboard is 
sold by most electronics parts distributors 
that distribute Intel components. 

The board is also available from several 


PC board-—level 
including: 


product vendors, 


Compubyte Inc. 

236 German Blvd. 
Yaphank, NY 11980 
(516) 924-1618 


Sabet Electronics 

2644 Forest Grove Dr. 
Richardson, TX 75080 
(214) 644-8306 


386 Corp. 

14126 Sherman Way, 
Ste. 562 

Van Nuys, CA 91405 
(818) 904-1386 


The Intel iSBC 386AT motherboard is 
also used in systems offered by several 
mail-order vendors, including: 


Corvus Systems Inc. 
160 Great Oaks Blvd. 
San Jose, CA 95119 
(408) 281-4100 


Eltech Research Inc. 
1725 McCandless Dr. 
Milpitas, CA 95035 
(408) 942-0990 


KayPro Corp. 

533 Stevens Ave. 

Solano Beach, CA 92075 
(800) 452-9776 


Laser Digital 

1024 Morse Ave. 
Sunnyvale, CA 94086 
(800) 846-4225, 
(408) 747-1966 in CA 


Lolir Computer 

13933 N. Central #212 
Dallas, TX 75243 
(214) 234-8056 


PC Discount 

2758 Bingle Rd. 
Houston, TX 77055 
(800) 843-7042 


ee 
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THE PROGRAMMERS SHOP 


helps save time, money and cut frustrations. Compare, evaluate, and find products. 


RECENT DISCOVERY 


OS/286 & 386 - Access 16M RAM 
in 286, 386 native mode. DOS 
interface, access. Use existing 
compilers or 32-bit FORTRAN, C, 
PASCAL. PC $ 495 


Al-Expert System Dev't 


Arity Combination Package PC $ 979 
System - use with C MS $ 229 
Auto-Intelligence PC $ 739 
CxPERT - shell for C MS $ 259 
Experteach - Powerful, samples PC $ 339 
Exsys PC $ 289 
Level 5 MS $ 659 
Intelligence/Compiler PC $ 739 
T.I.: PC Easy PC $ 435 
Personal Consultant Plus PC $2589 
Turbo Expert-Startup (400 rules) PC $ 129 


Corporate (4000 rules) PC $ 359 
Al-Lisp 


PC Scheme LISP - by TI 
Star Sapphire MS $ 459 
TransLISP - learn fast : 
TransLISP PLUS 

Others: IQ LISP ($239), IQC LISP ($269) 


Al-Prolog 


APT - Active Prolog Tutor - build 
applications interactively PC $ 49 
ARITY Prolog - full, 4 Meg 

Interpreter - debug, C, ASM PC $ 229 
COMPILER/Interpreter-EXE PC $ 569 
MicroProlog Prof. Comp./Interp. MS $ 439 
Prolog-86 - Learn Fast MS $ 89 
Prolog-86 Plus - Develop MS $ 199 
T 


URBO PROLOG si Borland PC $ 69 


BAS_C - economy MS $ 179 
BAS_PAS - economy MS $ 135 
Basic Development System PC $ 105 
Basic Development Tools PC $ 89 
Basic Windows by Syscom PC $ 95 
BetterBASIC PC $ 129 
Exim Toolkit - full PC $ 45 
Finally - by Komputerwerks PC $ 85 
Inside Track PC $ 49 
Mach 2 by MicroHelp PC $ 55 
QBase - screens MS $ 79 
QuickBASIC PC $ 69 


Quick Pak-by Crescent Software PC $ 59 
Quick-Tools by BC Associates PC $ 109 


Stay-Res PC $ 59 
True Basic PC $ 79 
Turbo BASIC - by Borland PC $ 69 


Turbo BASIC Database Toolbox MS $ 69 


XENIX 386 Toolkit by Santa Cruz. 
Tools & OS kernel support 4 Gigabyte 
address space, demand paging, virtual 
memory paging. Includes MS C, MASM, 
debugger, file utilities, more. PC $ 379 


HUMMINGBOARD 386-Develop 2.6 or 
7.9 times faster than a8 MHZ AT, 
AT or XT addin board uses dual 
processors for Speed and Hardware 
Debugging. 16 MHZ or 20 MHZ. Call 
about Benchmarks, Trial Program. 


“FREE” Software 


Instant Programmer’s Help for MSDOS de- 
velopers by Second City Software. Memory-resi- 
dent (TSR) utility lets you access valuable prog- 
rammer’s reference material from within’ any pro- 
gram. OS services, BIOS calls, ASCII codes, 
line and box drawing characters, video modes, 
keyboard scan codes, interrupts, 8088 assembly 
language, memory maps, FCB. 


Normally $79. With any order over $250 by 
11/30/87 get Instant Programmer’s Help (with 
2-month life span) FREE. 

Our Services: 


* Dealers Inquire 

+ Newsletter 

+ Rush Order 

* Over 700 products 
National Accounts Center 


+ Programmer's Referral List 

+ Compare Products 

+ Help find a Publisher 

+ Evaluation Literature FREE 

+ BBS-7 PM to 7 AM 617-740-2611 


C Language-Compilers 
AZTEC C86 - Commercial PC $499 
C86 PLUS - by Cl MS $359 
Datalight C - fast compile, good code, 

4 models, Lattice compatible, Lib 


source. Dev'rs Kit PC $ 77 
Datalight Optimum - C MS $ 99 
with Light Tools by Blaise PC $168 
Lattice C - from Lattice MS $269 
Let's C Combo Pack PC $ 99 
Microsoft C 5.0- Codeview MS $275 
Microsoft Quick C MS $ 69 
Rex - C/86 standalone ROM = MS $695 
Turbo C by Borland PC $ 69 
C Libraries-Files 

C Index by Trio/PLUS MS $319 
BTree by Soft Focus MS $ 69 
CBTREE- Source, noroyalties MS $ 99 
CTree by Faircom-no royalties MS $315 
rtree - report generation PC $239 
dB2C Toolkit V2.0 MS $249 
dbQUERY - ad hoc, SQL-based MS Call 
dbVISTA - pointers, network. 

Object only - MSC, LAT, C86 Call 

Source - Single user MS Call 
dBx - translator to library MS $299 


C-Screens, Windows, Graphics 


C Worthy Interface Lib. PC $249 
Curses by Aspen Scientific PC $109 
dBASE Graphics for C PC $ 69 
ESSENTIAL GRAPHICS - fast PC $185 
FontWINDOW/PLUS PC $229 
GraphiC - new color version PC $279 
Greenleaf Data Windows PC $159 
w/source PC $269 


Light WINDOWS/C-DatalightC PC $ 79 
TurboWINDOW/C - forTurboC PC $ 79 


Windows for C - fast PC $189 
Windows for Data - validation PC $319 
Vitamin C - screen I/O PC $159 
View Manager - by Blaise PC $199 
ZView - screen generator MS $129 


Atari ST & Amiga 


We carry full lines of Manx & Lattice. 


Call for a catalog, literature and solid value 


800-421-8006 


THE PROGRAMMER’S SHOP ™ 


Your complete source for software. services and answers 


5M Pond Park Road, Hingham, MA 02043 
Mass: 800-442-8070 or 617-740-2510 9/87 


RECENT DISCOVERY 


ACTOR by Whitewater Group - Graphic, 
object-oriented language for proto- 
typing, interactive programs and MS 
Windows applications. Fast feedback, 
integrated editor, debugger. Call 


to multiple languages. PC $419 


DBASE Language 


Clipper compiler PC $399 
dBASE II MS $329 
dBase III Plus PC $429 
dBASE III LANPack PC $649 
DBXL Interpreter by Word Tech PC $139 
FoxBASE+ - single user MS $349 
Quicksilver by Word Tech PC $439 
DBASE Support 
dAnalyst PC $ 89 
dBase Tools for C PC $ 65 
dBrief with Bricf PC Call 
dBC ISAM by Lattice MS $169 


Documentor - dFlow superset MS $229 
Genifer by Bytel-code generator MS $279 


QuickCode III Plus MS $239 
R&R Report Generator MS $139 
Seek-It - Query-by-example PC'S: 79 
Silver Comm Library MS $139 
Tom Rettig’s Library PC $ 79 


UI Programmer - user interfaces PC $249 


Fortran & Supporting 


50:More FORTRAN PC $ 95 
ACS Time Series MS $465 
I/O Pro - screen development PC $129 
MS Fortran - 4.0, full °77 MS $279 
No Limit - Fortran Scientific PC $109 
PC-Fortran Tools - xref, pprint PC $165 
RM/Fortran MS Call 


Scientific Subroutines - Matrix MS $129 


Multilanguage Support 


BTRIEVE ISAM MS $185 
BTRIEVE/N-multiuser MS $455 
GSS Graphics Dev’t Toolkit PC $375 
HALO Development Package MS $389 

Graphics PS $205 
Hoops Graphics Library PC $549 
Informix 4GL-application builder PC $789 
Informix SQL - ANSI standard PC $639 
NET-TOOLS - NET-BIOS PC $129 
Opt Tech Sort - sort, merge MS $ 99 


PANEL MS $215 
Panel Plus MS $395 
Pfinish - by Phoenix MS $229 


Polyboost - speed I/O, keyboard PC Call 
Prime Factor FFT - 8087/287 PC $145 
PVCS Corporate or Personal MS Call 


QMake by Quilt Co. MS $ 79 
Report Option - for Xtrieve MS $109 
Screen Sculptor PC $ 89 


SSP/PC - 145+ math routines PC $269 
Synergy - create user interfaces MS $375 
Xtrieve - organize database MS $199 
ZAP Communications- VT 100 PC $ 89 


FEATURE 
HI-SCREEN XL - unlimited overlapping 
windows, pulldown, popup, Lotus 
menus, on-line help support. Field 
checking, scrolling. Screen capture, 
more. Multi-language support. PC $129 
Note: All prices subject to change without notice. Mention this ad. Some Prices 


are specials. Ask about COD and POs. Formats: 3" laptop now available, plus 
200 others. UPS surface shipping add $3/item. 


Program 
Interfacing to 
Microsoft Windows 


by William Wong 


Part VI— 
Conclusion 


This series of articles has a twofold purpose. First, its intent is 
to give readers considering purchasing the Microsoft Windows 
Toolkit and writing a Windows application an insight into what 
is involved. Its second purpose is to help readers who have pur- 
chased the Toolkit or attended a Microsoft Windows seminar to 
write a typical application. 


This final article of William Wong’s series on interfacing to 
Microsoft Windows gives an overview of the major features not 
yet presented. Complete coverage of each feature would require a 
much longer article. Currently, the only book available on pro- 
gramming with Windows is Windows Programming Secrets by 
Kris Jamsa, published by Osborne/McGraw-Hill, Berkeley, 
Calif., although Microsoft will shortly release a book by Charles 
Petzold. The Microsoft Windows Programmers Toolkit is an- 
other good source of information. 


Menus and Dialog Boxes 

Menus and dialog boxes are the most apparent common items 
between applications. Windows helps by providing support in a 
standard fashion, making applications easy to learn once users 
understand the basic Windows interface. 

Menus and dialog boxes are resources created by the resource 
compiler program, RC. The text input to RC was described in 
Part II (MS/J, March/April 1987) of this series. It can be created 
by using a text editor or by using the dialog editor program, 
DIALOG. The dialog editor provides a graphic interface showing 
what a dialog box will look like. 

Each item in a dialog box can be identified, and its status can 


52 


be queried by an application. A dialog box is displayed using a 
Windows function that handles the interaction with the user. 
Applications can use additional hooks to modify this interaction 
as necessary. In fact, an item in a dialog box, such as a button, is a 
child window in which the item is drawn. 

Menu bars and pull-down menus are created in a similar fash- 
ion. There is a limit to what a pull-down menu can contain and 
the menus do not have to be used. It is up to the application to 
provide the interaction necessary for its operation. 

The main limitation of menus and dialog boxes is that they are 
bound to an application, and dynamically loading a menu from a 
different file is a complex procedure. 

Dialog boxes and menus simplify programming under Win- 
dows; they also make programs look and feel as though they are 
part of Windows. 


Memory Management and Atoms 

Windows provides memory management at two levels: local and 
global. Local memory management is similar to that found in C 
and DOS, in which a single contiguous space is managed. A local 
heap is contained within a global data segment and is accessible 
to a single instanceof a Windows application program. A global 
heap is a collection of sezments in the memory made available to 
Windows when it starts. 

Memory blocks or segments are referenced using handles or 
pointers. The latter can be used only when a block is locked. 
Blocks can be FIXED, MOVABLE, or DISCARDABLE. C pro- 
vides the idea of a FIXED memory block that will never move. 
Windows provides the idea of MOVABLE blocks. A MOVABLE 
block can change positions during a garbage collection operation, 
which is normally invoked when a new block needs to be allocated 
and there is not enough memory available. Windows first moves 
all MOVABLE blocks to one end of the allocation area and tries 
to fulfill the memory request. If this fails, Windows starts remov- 
ing DISCARDABLE blocks from memory. A memory allocation 
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Actor™ is a new language that combines Microsoft® Windows with 
object-oriented programming. This means you can produce mouse and win- 
dow applications very quickly. 

For example, we created a simple “paint” program, and used it to draw 
the Actor logo you see on the screen. The whole program only took ten lines 
and ten minutes. Part of it is in the middle window on the left. 

Above, you see the commands that initialized the paint window and 
made it appear on the screen. Below, some code that’s built into Actor, 
specifying window behavior. Through a process known as “inheritance,” it’s 
called into play automatically. 

Try programming in this new way, and youl never go back. 


And out about Actor. 
Call The Whitewater Group,(312) 491-2370. 
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request fails if there is insufficient memory after performing this 
process. 

MOVABLE and DISCARDABLE memory blocks are a bit 
tough to access without the additional support from Windows. 
Essentially, a lock can be placed on a block so it will not move. 
The application is given a pointer to the current location of the 
block. It can then manipulate the data and should unlock the 
block when the application has finished using it. Windows is then 
able to move a block, but an application must no longer use the 
pointer to the block. The locking process must be performed each 
time an application needs access to the data in the block, so the 
overhead can be expensive for frequent accesses. This approach 
provides a virtual-memory-like environment and also a cooper- 
ative environment like that of nonpreemptive multitasking. 

Data and code segments can be movable. Functions in MOV- 
ABLE segments require a special preamble and postamble to 
make sure that a function is in a fixed location when being exe- 
cuted. Windows supplies this support, so it is just a matter of 
indicating what functions are being used in this fashion. 

A block can be marked as DISCARDABLE when it may not be 
needed, although marking it does not necessarily unallocate it. It 
is up to the application to reload the data if it has been discarded 
and is needed again. Blocks in the local heap can be marked such 
that a function will be called when the block is about to change 
state. A limited form of virtual memory can be maintained using 
this facility. 

Atoms are text strings that can be added to but not deleted 
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from a Windows-maintained database. Atoms differ from the 
more conventional memory management support just described 
but provide a facility that is indispensible. The atom database is 
used for window class identification as well as being the basis for 
the Dynamic Data Exchange (DDE) protocol. 

Each atom has a number associated with it, and this number 
can be set at any time. The name of the atom provides a common 
access method—two applications simply need to know the name 
of an atom to share data. Each atom also has a unique handle 
associated with it. 

One way to use the atom facility is to allocate a global memory 
segment and place its handle in the atom database along with an 
atom. Other programs can then obtain access to the global data 
using the handle. 

Like everything else in Windows, the protocol and data format 
are cooperatively maintained. Windows imposes no specific use 
on the atom facility—in fact, the value associated with an atom 
need not be used. The atom handle is often used to provide a 
common and unique name for messages exchanged between win- 
dows of different applications. 

The atom facility and memory management support do not 
provide a virtual-memory environment, so resources are limited. 
Adding atoms to the atom database uses up memory resources. 


Communications 

Access to communication devices under DOS is done by direct 
hardware manipulation or through the ROM BIOS serial port 
support. Windows advances the state of the art through its com- 
munications driver. A Windows application can open a serial de- 
vice and specify handshaking methods and buffer sizes, leaving 
much of the work of sending and receiving data to Windows. 

The communications interface is standard among Windows 
implementations and hides the hardware from the application. It 
also allows a Windows application to operate in the nonpre- 
emptive multitasking mode without significantly impairing other 
programs that may be running at the same time. Communication 
programs that do not use Windows communication support must 
either hog the processor by polling the communications port or 
the programs must include custom interrupt driver communica- 
tions support. 

Windows’ communications support is somewhat limited and 
does not provide high-speed handshaking, which may be neces- 
sary for some communication protocols. The support is normally 
adequate for terminal emulation or file transfer protocols such as 
XMODEM or Kermit, however. 

A communications object has a handle associated with it, as do 
most Windows objects. The communications object must be re- 
leased by an application program before it terminates. 


Printing 

Printing using Windows is one of the more difficult tasks, even for 
text-based output. Essentially, the information to be printed 
needs to fit into memory unless the printer driver can send draw- 
ing-oriented commands in the same way PostScript printers can. 
Most other printers use a technique called banding. 

Banding requires several passes over the drawing database sup- 
plied by the application. Each band is set up as a memory device 
context, and the application draws the picture using the memory 
device context and then sends the bit map to the printer. The 
memory device context is clipped to the banding region. The band 
is then printed and the printer starts printing again. The process is 
repeated for each band until the application terminates. 
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The Clipboard 

The clipboard is both an application and a special Windows ob- 
ject that can be owned and manipulated. The clipboard applica- 
tion is really a simple program that can call a display function 
associated with the clipboard. There is only one clipboard and its 
owner is the last program that put something into it. Any applica- 
tion can read from the clipboard. 

The clipboard is accessed using several functions. But an appli- 
cation must be able to support one or more display methods, such 
as text, graphics, metafile, and so on. The number and type are 
not designated, but any application looking at the clipboard can 
recognize the type of formats available and choose the best one. 

The clipboard is normally used to exhange data between pro- 
grams under user control. The data in the clipboard can be propri- 
etary and may only be recognized by a corresponding program. 


Dynamic Linking and Dynamic Data Exchange (DDE) 

Windows requires a completely different .EXE file format that is 
similar to OS/2’s. This format is required to support the memory 
management methods as well as the link between an application 
and Windows. A Windows application calls a Windows function 
directly instead of using a software interrupt, as in DOS. This 
approach requires the .EXE file to contain the name of the called 
functions so that Windows can resolve the reference when the 
program is loaded. This process, called dynamic linking, provides 
an efficient interface and allows the environment to be flexible. It 
is even possible for an application to use the dynamic linking 
mechanism to access non-Windows functions. This is done by 
creating a dynamic link library module that can be loaded upon 
request. The dynamic link process provides one method of 
intertask communication because multiple programs can have 
access to a dynamic link function. 

Dynamic Data Exchange (DDE) is a mechanism that is built 
upon existing Windows functions, including the dynamic link fa- 
cility, atoms, and message passing. DDE allows tasks to exchange 
data, notify other tasks when data is available, and receive in- 
formation in an asynchronous fashion. DDE functions allow a 
program to identify a service using the atom facility, which main- 


tains a unique name for the service. Other programs can then 


WRITING WINDOWS APPLICATIONS 

Windows applications cannot be written in MASM or C alone. 
This is because the linker must understand Windows objects (for 
example, icons, dialog boxes) and linking to Windows is through 
a special call linkage, not an INT instruction. 

To write a windows application program, you need the Win- 
dows Toolkit ($500 list, but discounted to as little as $309) and 
the latest version of either Microsoft C, MASM, or Pascal. 
‘Microsoft conducts seminars for windows application program- 
mers at which the Windows Toolkit package is distributed. Pro- 
grammers who buy the Toolkit without attending the seminars 
are handicapped because the manuals contain little theory. This 
series of articles should assist programmers who buy the Toolkit 
without attending the seminars to write Windows application 
programs, It should also help seminar attendees. 

The Whitewater Group (Technology Innovation Center, 906 
University Pl., Evanston, IL 60201; (312) 491-2370) has intro- 
duced Actor, a lower-cost alternative to the Microsoft Windows 
Toolkit. Its documentation is poorer than that of the Toolkit, 
however, because it deals primarily with the Actor programming 
language. 


Micro/Systems JouRNAL NoveMBER/ DECEMBER 1987 


access this service using the same name. A service also provides 
several subservices that are named in the same fashion. DDE 
communication begins when a second task identifies a service and 
obtains the associated window handle from the atom facility. It 
then sends a message to the window requesting the service. 

The data that can be exchanged may be single records, a 
stream of records, or complete records of information when avail- 
able. The data can include text or binary data as well as window 
or memory handles. DDE is a standard protocol that Microsoft 
supports and recommends, and is being included in more and 
more applications, allowing a flexible working environment. 

DDE has many applications. It is one method for linking a 
spreadsheet to another program—for example, linking a 
graphing program to a communications program that returns the 
latest stock quotes. The DDE facility will become more important 
as more programs that support it become available—for example, 
OS/2 Version 1.1, which will contain the Presentation Manager. 


Windows 2.0, OS/2, and the Presentation Manager 
Windows, Version 1.03, has been available for some time. The 
next major release, which has already been demonstrated by 
Microsoft, will be Windows 2.0. From a programming point of 
view, little will change with Windows 2.0. There are some proto- 
col changes and some additional functions, but existing applica- 
tions will run under it. 

Windows 2.0 has one major change for users—tiled windows 
are no longer the norm; pop-up windows are everywhere. Win- 
dows 2.0 improves the user interface in other ways, too. For ex- 
ample, the up and down arrows, which were on the side slider, 
have now moved to the top-right. portion of the title bar. This 
allows quick scrolling using the buttons with the mouse by simply 
moving left or right and pressing the mouse button. 

OS/2’s Presentation Manager will look a lot like Windows 2.0. 
The new pop-up windows will be there along with other improve- 
ments. Applications designed for Windows will not run under the 
Presentation Manager without major changes, however, for sev- 
eral reasons. First, OS/2 is a preemptive multitasking system 
whereas Windows is nonpreemptive. Second, the programming 
interface is based upon a new set of functions that are a combina- 
tion of Windows and an IBM mainframe graphics interface. The 
new features should allow better performance of multitasking 
programs and shorten the development cycle for new programs. 


Summary 

Microsoft Windows is a viable base for developing PC-DOS/MS- 
DOS applications. Movement from 1.xx to 2.x is painless, but 
porting applications for either version of Windows with OS/2 and 
the Presentation Manager becomes more difficult. 

Developing new applications for Windows is a new approach to 
programming. Windows applications require a great deal of ini- 
tial support, making small and simple programs impossible, al- 
though creation of programs becomes easier once a familiar pro- 
gram base is built. 

Program development with the Microsoft Windows Toolkit is a 
high-cost, high-performance investment. Practical development 
requires an AT-class machine with at least a 20-Mbyte hard disk. 

Hopefully, this set of articles has presented the Windows devel- 
opment environment in a light that shows its magnitude as well as 
its flexibility. § 


Bill Wong is president of Logic Fusion, Inc., 1333 Moon Dr., 
Yardley, PA 19067, a systems software development firm. 
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Dealing 
with the 


DB-9 Serial Port 


IBM changes interface connectors on its 
mainframe and minicomputers frequently, 
most often just to hurt the competition. 
When it introduced the PC/AT, it intro- 
duced a new connector for its RS-232-C 
serial port—a DB-9 instead of the old DB- 
25-type connector. The DB-25 had been in 
use for so long that it had become a stan- 
dard for serial interfacing. This time I 
agree with IBM’s decision to change con- 
nectors. And other manufacturers are also 
switching as they see the advantages. 

The RS-232-C serial interface standard 
has been defined by the Electronic Indus- 
tries Association (EIA). RS stands for Rec- 
ommended Standard, and the C indicates 
that this is the third version of the standard. 
The standard utilizes a 25-pin connector, 
and manufacturers generally agreed on the 
DB-25-type connector with the modem 
(the Data Communications Equipment, or 
DCE) being a female connector and the 
terminal or computer (the Data Terminal 
Equipment, or DTE) being a male connec- 
tor. Until the introduction of the IBM PC, 
however, manufacturers used male and fe- 
male connectors as they wished. 

The EIA standard defines the function 
of 20 of the 25 pins, and it specifies how 
many must be used. There was a time 
when modem interfaces used most of the 
pins. Over the years, however, modem 
hardware interfaces have become simpler 


by Sol Libes 


as computers and modems have become 
more intelligent. The current generation 
of modems uses only nine lines. Serial in- 
terfaces to printers require even less 
wires—typically only three. 

Why then use a 25-pin connector when a 
9-pin connector will do? As computers get 
physically smaller, the room for connectors 
becomes more limited. Also, manufactur- 
ing costs have become more important in 
today’s highly competitive marketplace. It 


Figure 2. RS-232 pin functions 


is therefore only natural that computer 
manufacturers seek a connector better 
suited in size and cost to today’s needs. 

The DB-25 25-pin serial connector will 
no doubt be a thing of the past in a few 
years. Unfortunately, today it is still popu- 
lar, and it is often annoying to have to con- 
nect a serial modem or printer with a DB- 
25 connector to a computer with a DB-9 
serial I/O connector. 

It is not difficult to make up a DB-9 to 


Connector 


RS-232C 
Name DB-25 DB-9 
AA , 
BA 
BB 
CA 
CB 
CE 
AB 
CF 
CD 
CE 


Core AD Or7IW WN 


* not used 


Pin Nos. 
Signal Name 
(Chassis Ground) 
TxD (Transmit Data) 
RxD (Receive Data) 
RTS (Request to Send) 
CTS (Clear to Send) 
DSR (Data Set Ready) 
SG (Signal Ground) 
DCD (Data Carrier Detect) 
DTR (Data Terminal Ready) 
RI (Ring Indicator) 


Signal 
Direction 
common 

output 

input 
output 
input 
input 
common 
input 
output 
input 
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Figure 1. DB-9 to DB-25 interconnections Figure 5. DB-9 to Diablo 630 interconnections 
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Figure 6. DB-9 to Qume Sprint 9/45 interconnections 


Figure 3. Null modem wiring, DB-9 to DB-25 
Computer Modem 
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Figure 4. Null modem wiring, DB-9 to DB-9 Figure 7. DB-9 to NEC 7700 interconnections 
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DocuMotion for project mgrs: Ata special introductory np meet etaebaadir 
ice of ONLY $159.95 -pin connector. The cable wiring for this 
° Programmers produce more and sangeet paatyeek Kf machine is shown in Figure 5. Many serial 
better documentation. ee ee eS rinters use the DB-25 connector. The 
° Reduced function redundancy. Demo disk for $10.00 that puts the aes i me 
© Greater programmer productivity. ANSI ‘C’ library functions on-line. wirings for two popular serial printers (the 
Qume Sprint 9/45 and NEC 7700) using 
NWP - Intelligent Solutions, Inc. P.O. Box 20478 Bloomington, MN. 55420-0478 ne DBs connate arcana Rigites 
6and 7. § 
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RealWorld 


ACCOUNTING SOFTWARE 
-Version 4.0 
-All Modules 
-Multiuser 
for 
PC-MOS/386 
Concurrent-Dos / CPM86 


Upgrades Availlable 
for 
Release 2.1, 3.0, 3.1 
MASTER DISTRIBUTOR 


Paul Black & Associates 
1524 Eubank Blvd. N.E. Suite 2 
Albuquerque, NM 87112 
505-298-7044 


DEALER INQUIRIES INVITED 


ss C DATA ENCRYPTION 


Data Encryption Standard (U.S. government 
standard FIPS PUB4S6) in Microsoft "C". 
Includes compression & telecomm formatting, 
allowing faster transmission & less storage 
space plus compatibility with any computer 
or service. Complete "C" source code $249. 


s2a CASINO CARD GAMES 


Just like you’ve seen in Vegas and Atlantic 
City! You get BlackJack, Slot Poker, and a 
"bluffing" game of Draw Poker! BlackJack 
allows play variations & tracks statistics. 
Super card graphics & windows. CGA or Mono. 


ss3 POPUP TIME & BILLING 


records’) billable and non- 
time and expenses for attorneys, 
CPAs, and consultants. Different billing 
rates for multiple employees, detail & 
summary time period billing reports, built 
in help manual and popup menu operations. 
«@ Y 4 “HAWKEYE BOX 1486, OLDSMAR 
(A) GRAFIX Inc FLORIDA 33557 

nad DIAL 813-855-5846 


InsideTrac 
billable 
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Step into the Future 


Rrook 


MODULA-2 


for 8086 family machines 


jaro” 


“might have what we 
‘have NOW: 


@ Compiles 5K lines / minute on PC/AT 
e Runs Sieve faster than Microsoft C V4.0 


FLEXIBILITY 


© Generates Microsoft standard objects 
© Supports 6 memory models + mixed model 
e Interfaces directly to other DOS languages 
(you don’t have to throw 
out your C code!) 


powER 


e Full Modula-2 language 
+ Array and record constants 
+ Substrings and sub-arrays 

+ Tailorable procedure calling 


Mi 
PLUS 0S/2 and Microsoft 


Windows compatible NOW 


The generated code is compatible with OS/2 
and Microsoft Windows. Runtime libraries 
will be available soon. 


Story bree — yb Forest Road 
Seer Wilton, New Hampshire 03086 
SOFTWARE (603) 654-2525 


Compiler and DOS runtime $195 No other 
library objects only: M odula-2 


Above plus editor, source jler 
$345 corres close! 


debug, make utility, and 
runtime library sources: 

Add $5 shipping and handling in North America, $15 for over- 
seas orders. VISA and MasterCard accepted. 


Dm Special introductory offer: Purchase and pay for the complete 
system before Oct. 31, 1987 and get The Watcher execution pro- 
filer by Stony Brook Software — a $60 value — free. 
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A Linker for 
Turbo Pascal 


Expanding Turbo 
Pascal's Code Space 
Using a Module 


Turbo Pascal compiles quickly, produces 
tight code, and, with its built-in editor, is 
convenient to use. Turbo Pascal, however, 
does not support large memory models; 
compiled-code size must be smaller than 
61K. As the built-in library of Turbo Pas- 
cal occupies about 10K, a programmer 
can use only about 50K for code space. 
Using overlays is not an attractive pros- 
pect, especially when unused memory is 
available. Most programmers have a col- 
lection of procedures and functions that 
are used again and again in a variety of 
programs. In Turbo Pascal, those proce- 
dures and functions have to be included 
and compiled every time such subpro- 
grams are used. This repetition may in- 
crease compile time needlessly. 

This article describes a method of over- 
coming this code-size restriction. A sepa- 
rate file of Turbo Pascal source code that 
contains frequently used procedures and 
functions is compiled by Turbo Pascal into 
a .COM file. This .COM file is used as a 
library module, and the functions and pro- 
cedures included in it can be called from 
other Turbo Pascal programs (master 
module). The compiled library module is 
loaded onto the heap space of the master 
module during run time, so a library mod- 
ule, once prepared, neither occupies pre- 
cious code space nor wastes compile time. 
Currently, there are several commercial 
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by Sung K. Soh 


packages on the market that accomplish 
the identical task. Presented here is a do- 
it-yourself method without the automa- 
tion and convenience of commercial pack- 
ages, but it is free and gives the user 
complete control over the linking process. 
It has been tested on Turbo Pascal Version 


3.01A and is likely to work on Versions 2.0 
or 3.x without modification. 


LIBRARY MODULE 

Begin by collecting Turbo Pascal subpro- 
grams (procedures and functions) in one 
or more Pascal source files. They must be 


Listing 1 


{ This program tests Turbo Pascal Linker 


(C) Copyright 1987 by Sung K Soh 


Only personal, non-commercial use by Micro Systems Journal 


readers allowed. 
All other rights reserved. } 


{$I TEST1.PAS} 
{$I TEST2.PAS} 


{ Procedure linker will generate 


necessary call instructions to 


enable calling of module procedures from main program. } 


PROCEDURE linker; 
BEGIN 
INLINE ($58/ 
$2E/$A3/*+23/ 
$8B/SE5/ 
$5D/ 
$58/ 
$2E/$A3/*+13/ 
$D1/SE6/ 
$BB/* + 23/ 
$03/SDE/ 
$2E/$FF/$17/ 
SEA/$00/$00/$00/$00) ; 
END; 


POP 
MOV 
MOV 
POP 
POP 


AX } 

CS:* + 23, AX } 
SP, BP } 

BP } 

AX } 

MOV CS:* + 13, AX } 
SHL SI,1 } 

MOV BX, * + 23 } 
ADD BX,SI } 

{ CALL CS: [BX] } 

{ JMP Return Address } 


Sa Sa Gi ita ge Pa EE G GPE, 


{ Main block of module. Replace testl/test2/ sequence by a lsit 
of subprograms to be called by far call. } 


BEGIN 
INLINE ($B4/$00/ 
$CD/$21/ 
test1/test2/linker+7) ; 
END. 


{ MOV AH, 
{ INT 21 } 
{ List Of Addresses } 


0 } 
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C CODE FOR THE PC 


source code, of course 
C Source Code 


Bluestreak Plus Communications (two ports, programmer’s interface, terminal emulation) $400 
Greenleaf Data Windows (windows, menus, data entry, interactive form design)... ... . $315 
Barcode Generator (specify Code 39 (alphanumeric), Interleaved 2 of 5 (numeric), or UPC) $300 
GraphiC 4.0 (high-resolution, DISSPLA-style scientific plots in color & hardcopy) $275 
Vitamin C (Mac Windows) $200 
Greenleaf Communications Libary Gaverrupt m0ds mdlora eentvol, XON-XOFF) $160 
Greenleaf Functions (296 useful C functions, all DOS services) ww $160 
Essential C Utility Library (400 useful C functions) . yo es ws $160 
Essential Communications Library (C functions for RS- 232- banal communication systems) . $160 
PC/IP (CMU/MIT TCP/IP implementation for PCs) . $100 
B-Tree Library & ISAM Driver (file system utilities by Softfocus) . $100 
The Profiler (program execution profile tool) . % < $100 
Entelekon C Function Library (screen, eraphied, kavbound, wena: rs ete ae $100 
Entelekon Power Windows (menus, overlays, messages, alarms, file handling, etc.) . . $100 
QC88 C compiler (ASM output, small model, no longs, floats or bit fields, 80+ fanicbion! library) $90 
CBTree (B+tree ISAM driver, multiple variables length keys) . Lo choo fer oMer $80 
ME (programmer’s editor with C-like macro language e — Software) $75 
Wendin PCNX Operating System Shell . oie Bote es eee Gs $75 
Wendin PCVMS Operating System Shell . $75 
Wendin Operating System Construction Kit . . $75 
EZ_ASM (assembly language macros bridging C and MASM) . $60 
Multi-User BBS (chat, mail, menus, sysop displays; uses Galacticomm eietien ‘eard) . $50 
Heap Expander (dynamic memory manager for expanded memory) $50 
Make (macros, all languages, built-in rules) $50 
Vector-to-Raster Conversion (stroke letters & Tektronix 4010 eodes fo bitneape) $50 
Coder’s Prolog (inference engine for use with C programs) . . . $45 
PC/MPX (light-weight process manager; includes preemption sandl cooroutlie packages) $45 
Biggerstaff’s System Tools (multi-tasking window manager kit) . a aoe $40 
TELE Kernel (Ken Berry’s multi-tasking kernel) $30 
TELE Windows (Ken Berry’s window package) . = 8 $30 
Clisp (Lisp interpreter with extensive internals documentation) . ‘ $30 
Translate Rules to C (YACC-like function generator for rule-based syatena) $30 
6-Pack of Editors (six public domain editors for use, study & hacking) . $30 
ICON (string and list processing language, Version 6 and nese a $25 
LEX (lexical analyzer generator) : : $25 
Bison & PREP (YACC workalike parser eaiiciavor & suebuve grammar F preprocessor ; $25 
C Compiler Torture Test (checks a C compiler against K & R) ey sR ; $20 
PKG (task-to-task protocol package) bb aw ea $20 
A68 (68000 cross-assembler) . . $20 
Small-C (C subset compiler for 8080 and 8088) $20 
tiny-c (C subsubset interpreter including the tiny-c shell) $20 
Xlisp 1.5a (Lisp interpreter including tiny-Prolog in Lisp) $20 
List-Pac (C functions for lists, stacks, and queues) $20 
XLT Macro Processor (vaaeral purpose text translator) ‘ $20 
C Tools (exception macros, we, pp, roff, grep, printf, hash, dnalses ‘banner Pascale ie $15 
Data 

DNA Sequences (GenBank 48.0 of 10,913 sequences with fast similarity search program) . . $150 
Protein Sequences (5,415 sequences, 1,302,966 residuals, with similarity search program) . $60 
Webster’s Second Dictionary (234,932 words) oo $60 
U.S. Cities (names & longitude/latitude of 32,000 caf 8. aus nd 6 000 abate ondary: points) . $35 
The World Digitized (100,000 longitude /latitude of world country Noundaciel) SR « « $30 
KST Fonts (13,200 characters in 139 mixed fonts: specify — or — format) . $30 
NBS Hershey Fonts (1,377 stroke characters in 14 fonts) . Skew R RES $15 
U. S. Map (15,701 points of state boundaries) ‘ $15 
The Austin Code Works Voice: (512) 258-0785 
11100 Leafwood Lane BBS: (512) 258-8881 
Austin, Teras USA 78750-8409 Email: FidoNet 1:882/12 


Free surface shipping on prepaid orders MasterCard/VISA 


tested thoroughly, as errors may be diffi- 
cult to locate after their incorporation into 
a library module. Global variables may be 
used in the library module, but they will 
share the same data space with the master 
module. If you have to use global vari- 
ables, it is a good idea to copy the variable 
declaration statements of the library module 
and place them exactly in the same order 
at the start of the master module, before 
any other global-variable declarations of 
the master module. This ensures that the 
shared global variables will be assigned 
identical addresses when they are refer- 
enced by the library module and by the 
master module. Avoiding use of global 
variables in the library module makes 


in the in-line code, test//test2/ in Listing 
1, with the names of your public subpro- 
grams. They must be ordered correspond- 
ing to the tag numbers assigned. For ex- 
ample, if you have three subprograms 
named proc0, procl, and proc2, cor- 
responding to tag numbers 0, 1, and 2, re- 
spectively, you then replace test//test2/ 


with procO/proc!/proc2/. 

Now compile the prepared source with 
Turbo Pascal using the C compiler option, 
so the resulting .COM file will be saved on 
disk for later use. 


PREPARING INC FILE 
After the compiled library module is pre- 


Listing 2 


{ LINKER. INC 
(C) Copyright 1987 
by Sung K Soh 
Only personal and noncommercial use by Micro Systems Journal 
readers is allowed. 


All Other Rights Reserved. } 


{ Include this file in the main program to use compiled module. } 


TYPE FilenameString = STRING[80]; 


... a library module, 
once prepared, 
neither occupies 
precious code space 
nor wastes 

compile time. 


VAR LinkerAddr : “INTEGER; 


PROCEDURE initialize linker (Filename:FilenameString) ; 


VAR F : FILE; 
FIB : ARRAY[0..37] OF INTEGER ABSOLUTE F; 
size: INTEGER; 


BEGIN 
{$I-} 

ASSIGN (F,Filename) ; 

RESET (F) ; 

FIB(1] :=1; 

Size:=FILESIZE(F); 

FIB[1] :=128; 

GETMEM (LinkerAddr, Size+256) ; 

MOVE (MEM[CSEG:0], LinkerAddr*, 128) ; 

BLOCKREAD (F, MEM[SEG (LinkerAddr”) :OFS (LinkerAddr%) +256], 

FILESIZE (F) ); 


the module more portable and is 
recommended. 

Make a list of library-module subpro- 
grams that will become “public,” i.e., the 


subprograms that can be called from the a (F); 
F + 
master module located outside the code IF IORESULT<>0 THEN WRITELN(*G, 'Link Failed’) 
segment of the compiled module. Note ELSE 
that other “private” subprograms may ex- BEGIN 


LinkerAddr :=PTR (SEG (LinkerAddr”) , OFS (LinkerAddr%) +Size+244) ; 
LinkerAddr :=PTR (SEG (LinkerAddr’) , LinkerAddr”) ; 
END; 
END; 


ist in the compiled module, and that they 
may be called freely from within the mod- 
ule, but they will be inaccessible from out- 
side the module. This inaccessibility helps 
in hiding unnecessary details, and thus 
makes the compiled module more modu- 
lar. Assign tag numbers 0, 1, 2, and so on 
to the public subprograms. 

Now create a Turbo Pascal source file 
that will be compiled to produce the li- 


{ Copy procedure and function declarations to be called and 
include the inline code. Note that SI will be set equal to the 
serial number of module which must match the reverse order of 
addresses stored in the compiled module. } 


PROCEDURE test1(VAR x:REAL;i, j: INTEGER) ; 
BEGIN 


brary module by modifying Listing 1. Re- mami ils ' eae as : } 

place the {$I} compiler directives, which $BB/Linkeraddr / ( MOV BX, LinkerAddr } 
include TEST1.PAS and TEST2.PAS, so SFF/S2F); { JMP [BX] } 

that they will include your subprograms END; 


instead. Include the procedure linker, 
which acts as an intermediary between the 
library module and the master module, 


FUNCTION test2 (g:REAL) : INTEGER; 
BEGIN 


: : INLINE ($BE/$01/$00/ { MOV SI, 1 } 
just before the start of the main block of SOE/ { PUSH CS } 
the library-module program. The main $BB/LinkerAddr/ { MOV BX, LinkerAddr } 


SFF/$2F) ; { JMP [BX] } 


program of the module is used to store the 
addresses of the subprograms. Replace the 
list of the names of the library subprogram 
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pared, you must prepare an INC file, 
which will be included in the master mod- 
ule whenever subprograms in the library 
module are called. It can be prepared by 
modifying Listing 2. Replace subpro- 
grams test] and test2 in Listing 2 with 
function or procedure declarations of the 
subprograms in the library module. In the 
case of the previous example, they will be 
declaration statements for procO, procl, 
and proc2. Copy the in-line code for test] 
and test2 of Listing 2 for each and every 
subprogram that replaces test1 and test2. 
Change the second byte of the in-line 
codes, $00 and $01 for test1 and test2, re- 
spectively, with the tag numbers you as- 
signed for the library subprograms: $00 
for procO, $01 for procl, $02 for proc2, 
and so on. These tag numbers are assigned 
to the source index register SI before call- 
ing the procedure linker in the library 
module, so the procedure linker can deter- 
mine which library module is called. 


USING THE LIBRARY MODULE 

Compile your master module, which in- 
cludes the INC file just prepared, using 
the {$I} compiler directive before any ref- 
erence to the library subprograms are 
made. After the {$I} directive is used, the 
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CONCLUSION 

A Turbo Pascal linker program that works 
similarly to the ones on the market is de- 
scribed. It expands the effective code size 
of Turbo Pascal beyond 64K, yet the in- 
ternal workings of the linker are transpar- 
ent to the calling program and the subpro- 
grams called. The described method may 
be easily automated by users. § 


Dr. Soh is an assistant professor of 
chemical engineering at the University of 
Detroit. He is also vice-president of 
SoftTech, Inc., which specializes in math- 
ematical and engineering software for PC- 
DOS/MS-DOS microcomputers. He can be 
reached at the University of Detroit at 
(313) 927-1410 or at SoftTech, Inc., (313) 
544-8544. 


The author has an automated version of 
the described method available. It can be 
purchased for:.$15.00 and is in PC-DOS/ 
MS-DOS format only. Orders can be 
placed with SoftTech Inc., 14640 La Belle, 
Oak Park, MI 48237; (313) 544-8544. 


COMPLETE SOURCE CODE INCLUDED! 


ICXPDS: eXchanger now supports the 5 1/4"iPDS format. Manipulation 
of ISIS-II files using your computer system was never easier. 


ICXMDS: Same as ICXPDS, but for MDS 8” systems. 
IMXPDS: ReadsMrites 5” iPDS disks on PC's and AT’s. 
TELEDPLUS: Enhanced serial file transfer program for CP/M, ISIS, 


ISE: Emulator gives the CP/M and MS-DOS user access to all the ISIS-II 
languages and utilities. 


ACCELER 8/16: CP/M-80 emulator for MS-DOS. Enables PC's 
to run ISE. (no source code, V-20 incl.) 


$89 each 
$250 any 3 above 


UDI: The 8086 ISIS Emulator runs all UDI applications. 


ZAS Development Package: Z-8 and Z-8000 
Assembler for CP/M, ISIS, and MS-DOS. 


Request a catalog of our products! 


Copyrights CP/M Digital Research. Inc 
ISIS-I] and iPDS Intel Corp. MSDOS Microsoft 


Len Wares 303-327-4898 


_ BoxC * Norwood. CO 81423 
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The Scientific 
Computer User 


by A. G. W. Cameron 


FORTRAN 
Translation and 
Freelance Plus 


Technical Word Processors 

In this column I want to catch up on some 
software reviews. First, however, I would 
like to draw your attention to some exten- 
sive reviews of technical word processors 
(TWPs) that have resulted from a project 
of the IBM PC Technical Special Interest 
Group of the Boston Computer Society. 

This project had two phases. The first 
phase dealt with the ability of TWPs to 
reproduce various types of equations, ma- 
trices, and diagrams. The work on this was 
done in 1985 and the report was published 
in the January 1986 issue of the Notices of 
the American Mathematical Society. The 
second phase, in 1986, posed a tougher 
benchmark: the automatic generation of 
numbering schemes as part of the genera- 
tion of equations, tables, figures, refer- 
ences, chapters/sections, lists, headers, 
footers, footnotes, endnotes, and indexes. 
The report on this effort is much more ex- 
tensive, covering some 68 pages of small 
type in the January, February, and March 
issues of the Notices of the American 
Mathematical Society. You can get a re- 
print of it for $12 from Carl Hein, Dunster 
House Apt. 7, Swanson Rd., Boxborough, 
MA 01719. 

I was involved in both of these efforts vo 
some extent, having volunteered to try to 
do the benchmarks using TeX. I suc- 
ceeded, but only by subjecting TEX to 
some tortures that it was never intended to 
handle. For example, you are not supposed 
to draw diagrams or prepare such things 
as indexes with plain TgX, but the pro- 
gram is powerful and general enough to 
handle such tasks. It was a tremendous 
learning experience for me. The report 
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makes interesting reading and I recom- 
mend it to you. 


RTC Plus 

Cobalt Blue has produced a translator 
program to convert FORTRAN and RAT- 
FOR programs to C ($450). The first ver- 
sion sent to me for review handled only the 
RATFOR-to-C translation. However, re- 
visions that allowed some translation of 
FORTRAN also began arriving, so I held 
off the review until the FORTRAN trans- 
lation seemed to have stabilized. That now 
appears to be the case, although I have no 
doubt that further improvements will be 
made. 

It is the job of a compiler to translate a 
higher level language to assembly lan- 
guage; thus, a compiler is in fact a transla- 
tor program. The target language is gener- 
ally quite simple, but, being low level, it 
issues many instructions for every higher 
level statement that is translated. In the 
case of a translator program such as the 
one under review, both the original and 
target languages are high level and are 
likely to have very different syntaxes. 
Hence, the task of the translator program 
is generally more difficult than that of a 
simple compiler. It is not surprising, then, 
that RTC Plus neither claims nor delivers 
the ability to do 100 percent translations. 

First, a word about RATFOR since this 
is generally not a well-known language. I 
reviewed both RATFOR and the Software 
Tools computing environment in the Sep- 
tember 1983 issue of Microsystems maga- 
zine. Software Tools was in the first in- 
stance a book by B. W. Kernighan and P. 
J. Plauger (Addison-Wesley, Reading: 
1976). These authors showed how to write 
a large number of utilities in a largely ma- 
chine-independent way (only the lowest 
level made contact with the system). At 
the time, C was not widely available; most 
computing systems had FORTRAN in 
common. Thus Kernighan and Plauger 
wrote a FORTRAN preprocessor as one of 


the utilities and called it RATFOR (Ratio- 
nal FORTRAN). They also wrote all of 
the utilities in RATFOR, including RAT- 
FOR itself. RATFOR has many structures 
that are borrowed from the C language. 

The Kernighan and Plauger utilities 
generally duplicated those available in 
UNIX. Thus there was established the 
Software Tools User Group (STUG), 
which had as its goal bringing some of the 
advantages of UNIX to other systems that 
could compile the tools using FORTRAN. 
STUG also promoted the use of RATFOR 
as a substitute for C on systems that did 
not have it. 

The occasion for my previous reviews 
was the porting of Software Tools to CP/ 
M. There was a subsequent port of Soft- 
ware Tools to PC/MS-DOS. The company 
responsible for these ports (Carousel 
MicroTools) has long since ceased to do 
business, and it is not likely that there are 
many RATFOR users presently using mi- 
crocomputers. But RATFOR is generally 
available on UNIX systems, and it is possi- 
ble that a number of people who have used 
it there would wish to transport their 
RATFOR programs to microcomputers 
and then convert them to C. That was 
probably the original motivation behind 
the development of RTC Plus. 

I did not become a confirmed user of 
RATFOR. Generally, the FORTRAN 
compilation process was long enough, and 
the addition of the RATFOR preprocess- 
ing time on the front end became too frus- 
trating. What I did learn were the tech- 
niques used to translate RATFOR 
statements into FORTRAN. I found it 
useful to apply some of these techniques in 
writing FORTRAN programs, and thus I 
would characterize my exposure to RAT- 
FOR as a learning experience that let me 
write better FORTRAN programs. With 
the establishment of IF ... THEN ... 
ELSE statements in FORTRAN 77, even 
the use of some of these special procedures 
ebbed away. 
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Features: 
© Hitachi 64180 
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(executes a super- 
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* Centronics type parallel printer port 
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: + 12V at .05A 
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Software Tools 


For Programmers & Non-Programmers 


Get ‘State of the Art’ performance 
and save valuable time with these 
high quality utilities! 


Opt-Tech Sort” 


Opt-Tech Sort is a high performance Sort/Merge/Select 
utility. It can read, sort and write a file faster than most 
programs can even read the data. Example: 1,000 
records of 80 bytes can be read, sorted and a new file 
written in less than 10 seconds (IBM XT). Opt-Tech Sort 
can be used as a Stand-alone program or called as a 
subroutine to over 25 different programming languages. 


All the sorting, record selection and reformatting facilities 
you need are included. A partial list of features includes: 
The ability to process files of any size. Numerous 
filetypes are supported including Sequential, Random, 
Delimited, Btrieve, dBASE II & IIl and many others. Up 
to 10 key fields can be specified (ascending or descend- 
ing order). Over 16 different types of data supported. 
Powerful record selection capability allows you to specify 
which records are to be included on your output. Record 
reformatting allows you to change the structure of your 
output record and to output special fields such as record 
numbers for use as indexes. 


MS-DOS $149. * NEW * Xenix $249. 


vesion On-Line Help™ ‘ersion 

On-Line Help allows you to easily add ‘“‘Help Windows” 
to all your programs. On-Line Help is actually two help 
packages in one. You get BOTH Resident (pop-up) and 
Callable Help Systems. 

The resident version allows you to add help to any 
system. Your Help System is activated when the ‘‘Hot 
Keys” that you specify are pressed. You can then chain 
between help windows in any manner you desire. 


The callable version allows you to easily display help 
windows from your programs. A simple call to the help 
system makes the window appear. The original screen 
is automatically restored when the help window is 
cleared. On-Line Help is callable from over 20 different 
languages. 

You have full control over the help window content, size, 
color and location. 

MS-DOS $149. Demo $10. (apply toward purchase). 


Scroll & Recall” 


Scroll & Recall is a resident screen and keyboard 
enhancement. It allows you to conveniently scroll back 
through data that has gone off the top of your display 
screen. Up to 27 screens of data can be recalled or writ- 
ten to a disk file (great for documenting systems opera- 
tions). Also allows you to easily recall and edit your 
previously entered DOS commands without retyping. 

Scroll & Recall is very easy to use. It’s a resident utility 
that’s always there when you need it. MS-DOS $69. 


Visa, M/C, AMEX, Check, Money Order, COD 
or Purchase Orders accepted. 


To order or to receive additional information just call 
and receive immediate highly qualified attention! 
Opt-Tech Data Processing 
P.O. Box 678 — Zephyr Cove, NV 89448 
(702) 588-3737 
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Rack & Desk 
PC/AT Chassis 


A Fresh Approach 


Integrand’s new 

Chassis/System is not 

another IBM mechanical 

and electrical clone. 

Appearance, power, - 

thermal, reliability and EMI 

problems that plague other f 

designs have been solved. An entirely 

fresh packaging design approach has been 
taken using modular construction. At present, 
over 40 optional stock modules allow you to 
customize our standard chassis to nearly any 
requirement. Integrand offers high quality, 
advanced design hardware along with 


The RTC program was developed to 
translate RATFOR into C, but there is a 
much bigger market for translating FOR- 
TRAN programs into C. Thus Cobalt Blue 
developed FRAT, a program for translat- 
ing FORTRAN into RATFOR—Jjust the 
opposite of the normal approach. The 
standard sequence of operations using the 
Cobalt Blue scheme has four stages: (1) 
Use FRAT to convert FORTRAN (.for ex- 
tension) to RATFOR (.r extension); (2) 
use PRTC, a RATFOR preprocessor, to 
produce an intermediate file characterized 
by a .rc extension that normally disap- 


Listing 1 


pears after processing (unless there are er- 
rors); (3) use RTC to produce a nearly fi- 
nal C program (.cc extension); (4) finally, 
use a postprocessor CPOST to clean up a 
few things and produce the final C pro- 
gram (.c extension). 

There are two levels at which these pro- 
cedures can be used. Someone who wants 
a rough-and-ready translation to C can 
just go ahead and run these programs 
blindly. Some errors may be flagged that 
will need to be corrected before the trans- 
lation sequence will go to completion. The 
experienced user may modify the FOR- 


applications and technical support 
all at prices competitive with imports. 
Why settle for less? 


Rack & Desk Models : 
Accepts PC, XT, AT Motherboards 


and Passive Backplanes 
Doesn't Look Like IBM 
Rugged, Modular Construction 


Customize with over 40 Stock Panels 
Excellent Air Flow & Cooling 


Optional Card Cage Fan 
Designed to meet FCC 

204 Watt Supply, UL Recognized 
145W & 85W also available 
Reasonably Priced 

Made in USA 


Call or write for descriptive brochure and prices: 
8620 Roosevelt Ave. + Visalia, CA 93291 
209/651-1203 
TELEX 5106012830 (INTEGRAND UD) 
EZLINK 62926872 
We accept BankAmericard/VISA and MasterCard 


IBM, PC, XT, AT trademarks of International Business Machines, 
Drives and computer boards not included. 


This is a Fortran recipe from Numerical Recipes. 
Given an array DATA of length N, the program returns 
its mean as AVE and its variance as VAR. 

SUBROUTINE AVEVAR(DATA,N,AVE, VAR) 

Copyright (c) 1985 Numerical Recipes Software 

DIMENSION DATA(N) 

AVE = 0.0 

VAR = 0.0 

DO 11J=1,N 

AVE = AVE + DATA(J) 

CONTINUE 

AVE = AVE/N 

DO 12J=1,N 

S = DATA(J) — AVE 

VAR = VAR+S#S 

CONTINUE 

VAR = VAR / (N — 1) 

RETURN 

END 


Listing 2 


Program translated to Ratfor: 
# Translated by FRAT, v1.23, on 6-21-87 at 18:23:13 
subroutine avevar(data, n, ave, var) 
Copyright (c) 1985 Numerical Recipes Software 

dimension data(n) 
ave = 0.0 
var = 0.0 
do j =i,n { 

ave = ave + data(j) 

11 continue 


ave = ave/n 
do j =i,n { 

s = data(j) — ave 
var =Var+S*Ss 

12 continue 


var = var / (n — 1) 
return 
end 


Listing 3 


The Cobalt Blue C version: 
#include <stdio.h> 
#include <f77c.h> 
#include <swtdef.h> 
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TRAN code somewhat before submitting 
it to translation, and will make use of 
many command line switches on these dif- 
ferent programs. Cobalt Blue warns that 
many FORTRAN constructs will have to 
be rewritten to get a good translation, and 
that certain statements, such as those con- 
taining I/O statements will have to be 
hand-translated in any case. One can envi- 
sion that a truly clever translation process 
would do all these things automatically. I 
suppose the Cobalt Blue translation pro- 
cess may make significant progress toward 
this goal in subsequent versions. 


I tested RTC Plus by using it to translate 
202 FORTRAN routines taken from Nu- 
merical Recipes, by W. H. Press, B. P. 
Flannery, S. A. Teukolsky, and W. T. 
Vetterling (Cambridge University Press, 
New Rochelle, New York: 1986), which I 
have mentioned before in this column. 
These routines form a library of procedures 
that do not have I/O statements, although 
a few of them use complex numbers that 
RTC Plus does not like either. The advan- 
tage of using these routines is that Press, et. 
al., are bringing out a version of their reci- 
pes in C, and Bill Press kindly provided me 


= 


Listing 3, continued 


/*Translated by PRTC-RTC, v1.42, on 6-21-87 at 18:23:44*/ 
/*Translated by FRAT, v1.23, on 6-21-87 at 18:23:13*/ 
VOID /FUNCTION’/ avevar(data, n, ave, var) 

int #n; 

float data], +ave, *var; 


Prewesvees Copyright (c) 1985 Numerical Recipes Software */ 
(xave) = 0.0; 
(*var) = 0.0; 
{int tmpa_O = («*n); 
for(j = 1; | <= tmpa.0; j += 1 ){ 
(*ave) = (*ave) + data[j — 1]; 
Let: 


(save) = (*ave) / («n); 

{int tmpa_1 = («n); 

for(j = 1; | <= tmpa.t; j += 1 ){ 
s = data[j—1] — (*ave); 
(*var) = (*var) + Ses; 
LA2; 


, 


(evar) = (#var) / ((#n) — 1); 
return; 
} 7 end of func */ 


Listing 4 


The Numerical Recipes C version (alpha copy): 
void avevar(data,n,ave,svar) 

/* Copyright (c) 1987 Numerical Recipes Software */ 
/*200401*/ 

float data[],«ave, svar; 

int n; 


int j; 
float s; 
*#ave = (*svar) = 0.0; 
for(j = 1; | <= n; j++) «ave += datalj]; 
*#ave /= Nn; 
for(j = 1; | <= n; j++) { 
s=data[j] — («ave); 
*SVal += S # S; 


#svar /= (n — 1); 


| 
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with an alpha copy of these routines. These 
provide an independent human-translated 
set of C programs against which the trans- 
lations can be compared. 

Of these 202 FORTRAN routines, 36 
encountered some problem and did not go 
to completion. A common problem would 
be a statement like ERROR: intrinsic 
function args must all be the same type, 
(pass2), which would be a complaint 
against a common FORTRAN coding 
practice. RTC Plus also does not like to 
have array dimensions passed to a subrou- 
tine. In a few cases, internal errors were 
reported, which Cobalt Blue has warned is 
not supposed to happen but may happen 
due to as yet unreported bugs. 

Perhaps we should dwell less on the un- 
fortunate 36 routines that failed and con- 
sider that 166 were translated satisfacto- 
rily. These routines have what a C pro- 
grammer would consider very clumsy C, 
but most of them should do what they are 
supposed to do. You can get the flavor of 
the translation process by looking at the 
code in Listing 1. This is a short and sim- 
ple FORTRAN routine, AVEVAR, which 
provides the mean and variance of an ar- 
ray of numbers. Listing 2 shows the trans- 
lation to RATFOR and then to C; also 
shown for comparison is the hand-trans- 
lated version of this subroutine. 

The goal of a good compiler is to pro- 
vide tight and efficient machine language 
code. From Listing 3 we can see that RTC 
Plus does not presently produce tight and 
efficient C code. But many will find it 
helpful in partially automating the trans- 
lation process. 


Freelance Plus 

Freelance Plus is an interactive chart and 
plot program published by the Lotus 
Development Corporation and available 
for $495. I was interested in seeing if this 
type of program was becoming particu- 
larly useful for scientific work. I found it 
somewhat disappointing in that respect, 
but then I was probably expecting too 
much. The program does what it was de- 
signed to do quite well. 

In some respects it operates in the same 
way as a paint program. Its use of PC 
monitors, however, is restrictive. If you 
want to see things in color, you need an 
EGA monitor, since a CGA monitor shows 
only monochrome. The program works 
well with a Hercules card, and input can 
come from the keyboard or a mouse. 

Work is normally done with a number 
of graphic elements: text, lines, arrows, 
rectangles, circles, arcs, marker symbols, 
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and polygons. You can also do freehand 
drawing on the screen, however. Text is 
generated with a subset of the Hershey 
vectorized fonts and with thick sans serif 
fonts called “Swiss” (meaning Helvetica 
style). These can be rotated and scaled. 
Also available are software raster fonts in 
fixed sizes called “Sigma” fonts. The 
other graphics elements are usually cre- 
ated on the screen and then manipulated 
by translation, rotation, scaling, flipping, 
or other distortions. Clearly, the intended 
purpose of these operations is to prepare 
presentation material. Scientists may find 
the material useful for this purpose, since 
much of their work involves proposal writ- 
ing. But I do not find it useful for present- 
ing scientific results. 

In addition to supporting output on 
graphics screens, Freelance Plus supports 
some film recorders, a variety of plotters, a 
number of dot-matrix printers, and the 
Hewlett-Packard Laserjet. The lack of 
support for page description languages 
such as PostScript is surprising and disap- 
pointing. Much of what Freelance Plus is 
trying to accomplish involves the same 
kinds of manipulations that are available 
in PostScript. 

A number of scientists input data into 
Lotus 1-2-3 spreadsheets for analysis and 
plotting. For most purposes, that is as far 
as they need to go. However, 1-2-3 files (as 
well as a few other kinds of files) can be 
input into Freelance Plus and manipulated 
further. One might want to add boxed la- 
bels, for example, to a scientific plot. Sci- 
entists may find the program useful for 
this type of work. 

As for my personal preference, I find it 
more useful to approach the problem of 
plotting in a different fashion. In most 
cases I am plotting one or more dependent 
variables against an independent one, and 
the dependent variables are obtained from 
a FORTRAN computation of some sort. 
In these cases I find it useful to write a 
FORTRAN program to utilize this data in 
preparing a PostScript file to be sent to an 
Apple LaserWriter. This can use the 
LaserWriter’s internal fonts, which look at 
least as good and usually better than the 
Freelance Plus fonts. 

There is also an interactive plotting pro- 
gram called Mongo that was developed by 
John Tonry at the Center for Astrophys- 
ics. The program is easy to use for graph- 
ics primitives and has the advantage that 
all the interactive commands have equiva- 
lent FORTRAN calls that can be included 
in FORTRAN programs. It was developed 
on a VAX, and the program has spread so 


that it is now available on Sun work- 
stations and on PCs. Both of the latter im- 
plementations take output to a Laser- 
Writer. I would be more attracted to 
Freelance Plus if it had these capabilities. 


The Screen Manager 

While we are on the subject of screen dis- 
plays, I would like to take brief note of The 
Screen Manager, a series of program ele- 
ments published by Concept Software 
($149.95). Libraries and calling sequences 
are provided in assembler, C, and FOR- 
TRAN that allow the display of windows 
of arbitrary shape (as long as they are 
rectangles) on the screen. Text may be 
written to these windows (or read from 
them). The windows may be visible or in- 
visible and can overlay one another. They 
can also be moved around the screen at 
will. Foreground, background, and border 
colors and other attributes can be changed 
at will. Cursors are maintained for all win- 
dows in use. Windows and their contents 
can be stored to and recalled from disk 
files. 

The libraries sent for review included 
Microsoft C and FORTRAN, Lattice C, 
and Lahey FORTRAN. Probably other 
compilers and more recent versions of the 
above compilers are available now. 

These routines are more likely to be of 
interest to commercial program develop- 
ers than to typical scientists, who often de- 
velop a FORTRAN program and then run 
it once to get the answer to some problem. 
But quite a few programs become produc- 
tion items, run many times. In such cases, 
it may be worthwhile to display results in 
specific windows on the screen while the 
program executes. These libraries allow 
you to do that. § 


A, G. W. Cameron is professor of as- 
tronomy at the Harvard-Smithsonian 
Center for Astrophysics. 
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CPU 286 (8 MHz 3 cycle) $195 a4 
RAM 22 (256K-8/16 bit xtrs) $250 OT} Lh 4 "— 


The UNIX File 


lan & Darwin 


A Public Domain 
UNIX Clone and a 


C Programming 
Book for UNIX 
Users 


This column discusses the UNIX operat- 
ing system. If you have comments or 
questions about UNIX or this column, 
please write to Ian Darwin at Box 603, 
Station F, Toronto, Ontario, Canada 
M4Y 2L8. If you have UNIX mail access 
to the uucp network, mail “ihnp4!- 
darwinlian.”” Internet users should try 
“jan@darwin.uucp” or “ian@sq.com.”’ I 
can’t always answer immediately, but I 
will get back to you; electronic mail gets 
answered first! 


What's GNU? Source for You 

The GNU project is another attempt to re- 
write a UNIX-like system without any ref- 
erence to AT&T source code. And it could 
lead to a full-function, UNIX-like system 
that you can get for free, with full source 
code to put up on any 386 system. 

But GNU will not spell the end of com- 
panies that make their living by support- 
ing commercial UNIX systems. Since peo- 
ple are free to sell supported GNU 
systems, however, some of those compa- 
nies may well switch from selling sup- 
ported UNIX (which they must distribute 
without source) to supported GNU (dis- 
tributed with source). There is a place for 
public domain programs and systems in 
the technical community. Most business 
computer users want a stable, established 
product, so they will continue to buy 
AT&T UNIX from vendors who will pro- 
vide ongoing support for it. 

However, GNU should someday keep 
older UNIX systems alive and support new 
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ones, as well as freeing people from 
AT&T’s source-level pricing policies. For 
now, the Free Software Foundation has a 
number of GNU subsystems available, in- 
cluding the Emacs editor, a C compiler 
and source debugger, a chess program, 
and a compiler-compiler tool, and more 
software is being released as it is 
completed. 

GNU (the “g” is pronounced) is a 
project of the Free Software Foundation 
(FSF), and is intended to produce a work- 
ing clone of Berkeley UNIX. The FSF is 
primarily run by Richard M. Stallman, 
who is perhaps best known in the comput- 
ing community for having invented a com- 
prehensive editor program called Emacs. 
Emacs differs from most editor programs 
in several ways. For example, it allows you 
to change every mapping of a key to a 
command. The Emacs default simply in- 
serts into the edit buffer printable charac- 
ters that you type. But if you prefer the 
feel of an editor like vi in which letters are 
commands, you can simply map the letters 
to the appropriate commands, which can 
make Emacs look like vi, or WordStar, or 
KED/EDT, or almost any other screen 
editor. (Just try making WordStar look 
like Emacs!) Some editors allow limited 
mapping of function keys, but I know of no 
other editor that is completely reprogram- 
mable. Yes, I do mean programmable. 
You aren’t limited to changing the key-to- 
function mapping; you can also replace the 
existing functions, or even add your own, if 
you can write them in the LISP program- 
ming language. 

Stallman invented the Emacs editor, 
originally as a set of Editor MACroS for 
an enhanced MIT TECO editor. His view 
is that an editor is not an Emacs unless it is 
extensible, customizable, and_ self- 
documenting. His original Emacs ran on 
MIT’s Incompatible Timesharing System 
(a pun on CTSS, the Compatible Time 
Sharing System) and was later ported to 
TOPS-10 and TOPS-20. An early Emacs 
clone was Multics Emacs, written by Ber- 


nie Greenberg using MacLisp as its exten- 
sion language, rather than obscure TECO 
macros. Later clones included James Gos- 
ling’s UNIX Emacs, which uses the Mock- 
Lisp extension language, a language with 
LISP syntax but not LISP data structures. 
Gosling’s Emacs is now sold and main- 
tained by Unipress. There are several mi- 
crocomputer Emacs-like editors that 
aren’t true Emacs because they are not ex- 
tensible or self-documenting, but they 


have screens and default keyboard map- 
pings that look like real Emacs. They are 
more powerful than the editors most micro 
vendors provide. 

Stallman has also been instrumental in 
shaping the MIT AI lab over the years, and 
in developing the ITS timesharing system, 
a multiuser, networked operating system. 
Recently, Stallman came out with a new 
Emacs called GNU Emacs. The good news 
is that it can be copied and customized by 
anyone, because full source is always pro- 
vided. The curious news is that it’s perhaps 
the first text editor to come complete with a 
political ideology wired in. 

Stallman gives away software free but 
maintains the right to control how it is re- 
distributed by copyrighting all the soft- 
ware in the name of the Free Software 
Foundation. The copying policy is clearly 
stated in every program and manual FSF 
distributes. GNU Emacs even has a key 
combination that displays the copying pol- 
icy. You can copy the software for any 
purpose, but must always give credit to the 
FSF as the originator. Further, if you 
modify the software and then redistribute 
it, you must make clear that you are 
distributing a modified copy, saying who 
modified it, and when. Finally, if you dis- 
tribute a binary-only copy, you must dis- | 
tribute an offer of free matching sources, 
available to anybody, and assignable. In 
other words, anyone who gets a binary 
program must be able to get the matching 
sources. The recipient can redistribute the 
binary, as well as redistribute the right to 
get the matching sources. 
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G and Pascal 


for MS-DOS 


' MetaWare Incorporated announces the first 


available C and Pascal compilers that generate 


protected-mode 80386 code 


for running on any 80386 machine that runs MS-DOS (eg., the 
Compaq Deskpro 386 or the IBM Personal System/2 Model 80). 
The compilers are functionally identical to our well-respected 
8086/286 MS-DOS High C™ and Professional Pascal ™ com- 
pilers, but now you can get them generating 80386 code. 

There's no reason to wait! Industry leaders such as ANSA and 
Fox Software are already converting their 16-bit database products 
to 32-bit protected mode, getting increases in speed and function- 
ality. Don't wait years for Microsoft's 386DOS — your competition 
will have a big jump on you! 

Expand your application to the large 32-bit address space and 
the full 32-bit registers of the 80386. Contact MetaWare for your 
80386 software solution today! 


(408) 429-6382, telex 493-0879. 


Mats NN, Ws" 


INCORPORATED 
903 Pacific Avenue, Suite 201 ¢ Santa Cruz, CA 95060-4429 
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* Demo Disk (includes $5.00 Credit wees 


+ Custom Emulation Modules $ CALL 


AIA 
SS ee"! 
Seawe (305) 777-7080 cn 


Concurrent Research Dealer Inquiries Invited = 


SIXTEEN MEGABYTES 


IN ONE SLOT 


The PC Tech Sixteen Megger board gives you 16 Megabytes of 
fast Dynamic RAM in a single slot. 


The Sixteen Megger works in the IBM PC/XT/AT and compatibles 


at all speeds from 4.77 to 10 Mhz. 


On an XT, the Sixteen Megger can be 


used as 8 bit wide, bank switched, 
expanded memory. 


On an AT, the Sixteen Megger is 16 
bits wide and can be used as ex- 
panded or extended memory or a 
combination of the two. 


The Sixteen Megger comes complete 
with software for the Lotus/In- 
tel/Microsoft Expanded Memory 
Specification, as well as a fast 
memory disk program and an exten- 
sive diagnostic program. 


Priced from $475 for 2 Megabytes to 
$4,250 for a full 16 Megabytes. Four 


available. 
Another smart idea from PC Tech. 


short card, $850. 


cee 
904 N. 6th St. 
Lake City, MN 55041 
= (612) 345-4555 


Designers of the X16 and Other Fine Computer Products 


Conquer Time 
and Space. 


Introducing XO-SHELL. 


Pop-Up Productivity for Programmers. 


No matter what language you program in, XO-SHELL will help 
you hurdle the barriers to working faster and more efficiently 
by eliminating programming hassles. Only with RAM-resident 
XO-SHELL can you: 

DO CROSS-REFERENCING without leaving your editor 

VIEW ANY FILE and TRANSFER ANY SECTION into your 

editor or to your printer 

VIEW, COPY and ERASE files directly from a SCROLLABLE 

DIRECTORY DISPLAY 

With a single key stroke RETRIEVE previous DOS commands, 

then EDIT and REEXECUTE them 

DO SOURCE-LISTING while in your application 


OBTAIN KEY-CODES without a reference and without going 
through difficult interpretation 


INSERT GRAPHICS CHARACTERS in your source code. 
XO-SHELL is for PCs, XTs, ATs, PS/2s, compatibles. 


Call now for special half-price introductory offer. 


For a limited time only 


$24.50 
(regular price $49) 
™ plus $5 shipping & handling 


Call today toll-free 
LUUTE (800) 635-5011 


WYTE CORPORATION (In MA: (617) 868-7704) 


701 Concord Avenue 
Cambridge, MA 02138 Visa, MasterCard 


and Eight Megabyte versions are also 


Still available: The Four Megger, four 
megabytes of expanded memory on a 
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As for prices, the copying policy says 
you can charge anything the market will 
bear for GNU software, but the price must 
include sources or the offer of sources. 
There can be no additional fee for source 
code. There is also an explicit lack-of- 
warranty statement; since you don’t pay 
commercial rates for the software, it’s only 
fair that you not hold the Free Software 
Foundation responsible for any problems 
you may have, and the no-warranty state- 
ment makes that explicit. 

Some detractors label Stallman a com- 
munist. Others call him an eccentric. To 
those who believe in what he’s doing, he’s 
an idealist or evangelist, putting his own 
professional survival on the line to show 
the world a better way to make computers 
more useful. Whatever the ideology, FSF 
has produced some large and impressive 
works. Although a full UNIX-like system 
isn’t ready yet, the following items have 
already been released, including: 


® GNU Emacs—A full Emacs editor, in- 
cluding LISP function extensibility; 

@ bison—A replacement for the yacc 
parser generator; 

@ gcc—A C compiler, compatible with 
the draft ANSI C standard, with code 
generators for the VAX, 68000, and 
68020 (gcc tries to make it easy to write 
new code generators; it’s not limited to 
the preceding machines, and comes 
with info about porting to other proces- 
sors. Users have written, and contrib- 
uted, prototype code generators for the 
NS32032 and the IBM 370); 

@ gas—The GNU assembler, currently in 
beta test; 

®@ gdb—A source-level debugger for the C 
language; 

®@ chess—A serious chess-playing pro- 
gram; 

@ Scheme—A “simplified, lexically 
scoped dialect of LISP,” developed pri- 
marily at MIT; and 

@ miscellany—FSF also distributes MIT’s 
X Window System (which is in the pub- 
lic domain) and a version of the Hack 
adventure game. 


That’s only what is available already. 
Stallman also has GNU shell (gsh, a csh 
emulation), which is in alpha test, and 
most of the commonly used UNIX utilities 
working in-house. The kernel will proba- 
bly derive from the MACH project at Car- 
negie-Mellon University, or possibly from 
the TRIX system written at MIT. And 
most of the rest of a UNIX clone is now in 
test or development. Many people in the 
UNIX community and other parts of the 
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industry (VAX/VMS users, non-UNIX 
supermicro users) support the idea of a 
full-blown, UNIX-like system with source 
availability, and they are contributing 
their time and energy to expand and im- 
prove this software. It’s hard to say when 
the system kernel and utilities will be re- 
leased, but new software is released peri- 
odically and eventually there will be a 
working kernel and utilities for a full 
UNIX-like system. 

What will it mean? People who want to 
do kernel development on a Berkeley-like 
UNIX system will no longer need to obtain 
an AT&T source license (which costs 
about $60,000 for System V) and then get 
a Berkeley license; they can get the whole 


To the owner 

of an orphaned 
68000 or similar 
computer... 

GNU will mean that 
a UNIX-like system 
with source code 

is now available... . 
GNU is designed for 
modern processors that 
will continue to be 
popular... 


package from FSF for the cost of a tape. 
Better yet, they can get it from a friend for 
no cost at all! 

To the owner of an orphaned 68000 or 
similar computer—those whose manufac- 
turers have gone bankrupt or who have 
stopped supporting older machines—it 
will mean that a UNIX-like system with 
full source code is now available. One can 
even envision small entrepreneurs making 
a modest living by supporting orphaned 
UNIX computers. Such machines, which 
now sell for about $4,000, might make 
good systems for hobbyists willing to port 
GNU. 

What will GNU mean to owners of 
smaller machines? Recall that GNU is 
meant to be a clone of Berkeley UNIX, not 
of V6 or V7. GNU is designed for modern 
processors that will continue to be popular 
over the next few years, not for processors 
(like the 8088) that have been obsolete for 
years. Berkeley UNIX is not small. Don’t 


ever expect to run GNU on your PC/XT, 
nor probably on your AT or on your PDP- 
11. For such machines, Tanenbaum’s 
MINIX system (described in this column 
in the May/June 1987 issue of M/SJ) is a 
better bet. MINIX is also a UNIX system 
clone, but one designed from the start to 
run on small systems. Version 7 of Com- 
er’s XINU system (reviewed here in the 
March/April 1987 issue of M/SJ), while 
not a UNIX clone, does have some of 
UNIX’s functionality, and was designed 
for use on the LSI-11 processor. 

GNU expects 32-bit integers and 32-bit 
pointers, with 8-bit-byte addressing. It 
also requires at least 1 Mbyte of RAM, 
and a sizeable hard disk—40 Mbyte is a 
bare minimum capacity but 80 Mbyte is 
the recommended minimum. To be able to 
use demand paging and relocation, expect 
to upgrade an existing 68000 to a 68010 or 
68020 chip, plus have a memory manage- 
ment unit, such as the M68451. Inexpen- 
sive machines like the Macintosh 2 or an 
existing UNIX supermicro are good candi- 
dates. A full-blown 80386 system with ad- 
equate RAM and hard disk also would 
make a good GNU machine. 

By contrast, MINIX will work on a PC 
with 256K and two floppies, but keep in 
mind that it’s MIN-ix, a minimal UNIX 
clone. MINIX is owned by Prentice-Hall 
and they do not encourage copying. They 
allow minor copying, on author Andy 
Tanenbaum’s insistence, but not large- 
scale redistribution. For example, posting 
Tanenbaum’s complete MINIX distribu- 
tion to the USENET network or on a bul- 
letin board system would be discouraged. 
And Comer’s XINU is copyrighted—you 
cannot legally give it to your best friend. 

FSF, on the other hand, actively encour- 
ages people to copy GNU and give it to 
their friends. It also provides tape duplica- 
tion services because such services are con- 
venient for some recipients and also be- 
cause these services provide an easy way 
for users to donate money to the GNU 
project in a way justifiable to manage- 
ment. There is no attempt, though, to pre- 
vent massive duplication by anybody. If 
you can find a million people who will buy 
it from you, then that’s a million more who 
have heard of free software, which is the 
goal of the FSF. You can post GNU soft- 
ware to the net, assuming the net is happy 
with its size, or put it up on a BBS, as long 
as you follow the copying policy. 

Interestingly, vendors of UNIX and 
UNIX-like systems are encouraged to dis- 
tribute GNU software with their systems. 
Again there is no license fee, but the copy- 
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ing rules must be followed. FSF software 
also comes with extensive documentation. 
If you order the software from them, you 
pay a modest fee for the tape and ship- 
ment. You can also order neatly printed 
copies of the manuals. 

For details on what’s currently available, 
current copying policies, status, and future 
plans, contact the Free Software Founda- 
tion Inc., 1000 Mass Ave, Cambridge, MA 
02138, or call (617) 876-3296.1 


A Book on C for Berkeley Users 

In contrast to books that attempt to cover 
all aspects of using various UNIX systems, 
Nigel Horspool at the University of Vic- 
toria has written C Programming in the 
Berkeley UNIX Environment (Prentice- 
Hall, Scarborough, Ontario, Canada, 
1986). The book is aimed at students who 
have some programming experience and 
includes such topics as the standard fea- 
tures of the C language; the standard C 
library; system calls and library routines; 
debugging (there are cursory comments 
on adb, sdb, and some detail on dbx, 
whereas most UNIX books cover only one 
of these); advanced system features such 
as pipes, and signals; and an overview of 
networking and terminal handling. Ap- 
pendixes cover the vi text editor, the 


1 John Gilmore of Nebula Consultants 
provided significant information on GNU 
and Emacs for this section. Portions of this 
column were derived from material copy- 
righted by Gilmore and by the Free Soft- 
ware Foundation. 


Berkeley shell csh, and summaries of the 
C language and the library calls. There is 
a list of answers to the exercises and an 
index. Many topics that are commonly 
omitted or inadequately discussed in other 
books, such as correct use of C language 
header files, the make program, and so on, 
are included here. 

The book discusses only Berkeley UNIX 
and C; it makes no attempt to cover other 
UNIX variants. That is at once the book’s 
strength and its greatest weakness. Al- 
though it does cover the relevant material, 
it does not take enough pains to detail 
what is portable to other UNIX systems 
and what is not. I suspect this may be sim- 
ply because Horspool has not been ex- 
posed to enough other systems. For exam- 
ple, he uses the library function bcopy as 
though it were a standard part of all 
UNIX systems, which it’s not. He refers to 
mail (with a lowercase m) as the program 
that prints a header list and reads your 
.mailre file, but on non-Berkeley UNIX 
systems that name invokes a different mail 
program, and the one he describes is in- 
voked (if it’s available at all) under the 
name Mail (capital M) or mailx (mail ex- 
tended). And he states that Kernighan and 
Pike’s The UNIX Programming Environ- 
ment is “intended to be a companion to 
System V UNIX” because it omits the 
Berkeley system calls; in reality, 
Kernighan and Pike have described a com- 
mon subset of Research UNIX (V7/V8), 
System V UNIX, and (with a few excep- 
tions) Berkeley UNIX. 

In fairness, Horspool does refer the 
reader who is interested in portability to 


PERISCOPE  ~- 


ssKeeps you going full steam 
ahead when other debuggers 
let you down. With four 
models to pick from, you'll 
find a Periscope that has just 
the power you need. 


. Start with the model that fits your current needs. If 
you need more horsepower, upgrade for the difference in price plus $10! 
And don’t worry about having a lot more to learn. . . 
move to the most powerful model, Periscope III, an extra dozen com- 


mands are all that’s involved. 


Periscope’s software is solid, comprehensive, and flexible. It 
helps you debug just about any kind of program you can write. . . 


Top-of-the-line Periscope 
Ill with real-time, hardware 
breakpoint board. 


another source. Having administered 
UNIX systems myself in both the commer- 
cial world and academia, and having 
taught undergraduates about UNIX, I con- 
tend that students should not emerge think- 
ing that they know the one true UNIX ver- 
sion. They should be taught what is 
portable and what isn’t. All the world is not 
a VAX, nor does all UNIXdom run 
4.2BSD. More footnotes on the differences 
would be a big help, as would more consis- 
tency. For example, in the discussion of sig- 
nal handling, Horspool explains the correct 
procedure for checking whether signals are 
currently being caught, but not one of his 
examples uses it. And he introduces malloc 
on page 48, with examples, but he does not 
mention until page 108 that you must 
check the return value from it. It has been 
my experience that students rely heavily on 
examples, often starting to experiment with 
some feature of the system by typing in an 
example from a book, so it is important 
that the examples be correct. 

Despite these minor flaws, the book cov- 
ers the material that it promises. Rec- 
ognizing that no one book will satisfy ev- 
ery UNIX user all the time, I would 
recommend that this book be given serious 
consideration for use in undergraduate 
teaching. § 


Tan Darwin is Director of Research and 
Development for SoftQuad Inc., Toronto 
developers of quality UNIX-based pub- 
lishing software. Ian previously adminis- 
tered UNIX systems, and organized and 
taught the undergraduate UNIX course, 
at the University of Toronto. 


¢ POWER 


Periscope I includes a half-length board with 
56K of write-protected RAM; break-out switch; 


software and manual for $345 
Periscope II includes break-out switch; software 
and manual for $175. 
Periscope II-X includes software and manual 
(no hardware) for $145. 


Even when you 


Periscope III includes a full-length board with 64K of 
write-protected RAM, hardware breakpoints and real-time trace buffer; 
break-out switch; software and manual. Periscope III for machines run- 
ning up to 8 MHz is $995; for machines running up to 10 MHz, $1095. 


Call Toll-Free for free information or to order your 


Periscope today! 


thoroughly and efficiently. Periscope’s hardware adds the power to solve 


the really tough debugging problems. 


Periscope requires an IBM PC, XT, AT, or close compatible 
(Periscope III requires hardware as well as software compatibility); DOS 
2.0 or later; 64K available memory; one disk drive; an 80-column 


monitor. 
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The 


Company, Inc. 


MAJOR CREDIT CARDS ACCEPTED. 


PERISGOPE 


800-722-7006 


14 BONNIE LANE 
ATLANTA, GA 30328 
404/256-3860 
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New Products 


When contacting vendors, please mention 
that you read about their products in 
Micro/Systems Journal. 

Manufacturers who would like to have 
their hardware products listed here 
should send their news releases to the 
Managing Editor, Micro/Systems Jour- 
nal, 501 Galveston Dr., Redwood City, 
California 94063. 


PC-COMPATIBLE 
HARDWARE 


Hi-Res ADC/DAC Card 

The A/D12B32 is an Analog-to-Digital/ 
Digital-to-Analog Converter for PC com- 
patibles. The ADC can monitor up to 32 
inputs with 12-bit conversion. Input con- 
figuration (single- or double-ended) and 
gain (1x, 2x, 5x or 10x) is programmable 
on a per-channel basis via software pro- 
vided with the unit. Input voltage ranges 
from -5V to +5V. Two 8-bit DAC out- 
puts and 32-TTL parallel 1/O lines (plug- 
compatible with optoisolator modules 
from ICD) are also provided. 

The A/D12B32 is $995, and is manu- 
factured by Industrial Computer Designs 
Inc., 31364 La Baya Dr., Westlake Vil- 
lage, CA 91362; (818) 889-3179. 


Break 640K Memory Barrier on an 
AT and Run Concurrent Sessions 

The Software Link AT Gizmo and Multi- 
Link Advanced software are a hardware/ 
software combination that allow AT-com- 
patible machines to run most PC applica- 
tions in multiple sessions. It provides a 
shared-processor, multiuser, multitasking 
system that lets up to 17 applications/us- 
ers Share the Al. [The Gizmo is a card that 
attaches to the 80286 motherboard and re- 
maps memory creating up to 8 Mbytes of 
extended memory when used with an Intel 
Above Board-286. Each user/application 
can occupy up to 600K of memory in mul- 
tiple partitions. All applications can now 
take advantage of the LIM (Lotus/Intel/ 
Microsoft) expanded memory. Up to 16 
ASCII terminals can operate with a single 
host AT-compatible using standard RS- 
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232 connections. Record- and file-locking 
are provided for multiuser and networking 
support of applications such as RBASE 
System V, Smart and dBASE-III Plus. 

The suggested retail price for Multi- 
Link Advanced is $595, and a multi- 
tasking-only version (MTO) is $195. The 
AT Gizmo is $295. All are available from: 
The Software Link, 8601 Dunwoody PI., 
Ste. 632, Atlanta, GA 30338; (404) 998- 
0700. The Above Board-286 has a sug- 
gested retail price of $745 (with 512K 
RAM) and is available from Intel Corp., 
5200 N.E. Elam Young Pkwy., Hillsboro, 
OR 97124; (800) 538-3373. 


AT Replacement Battery 

International Battery Corp. has an- 
nounced the Tadiran replacement lithium 
battery for AT-compatibles, The battery is 
listed by Underwriters Laboratories and 
hence has passed all UL tests for aging, 


short-circuit, crush, heat and fire tests. 
The unit is guaranteed for three years in- 
use and ten years of shelf life. 

The IBC Tadiran replacement battery is 
$27.50 and can be ordered directly from 
IBC, 6860 Canby Ave., Ste. 113, Reseda, 
CA 91335; (818) 609-0516. 


Compact, Rugged PC /XT Compatible 
Slicer has introduced the SLY40-XT 
Turbo, a PC/XT-compatible that com- 
pany sources state is ideally suited for in- 
dustrial applications. This computer is 
composed of 17 low-power CMOS inte- 
grated circuits and resides in a 44- 


inch X 9%-inch printed circuit board. It 
uses an NEC 8-MHz V40 and supports 
one full megabyte of zero-wait-state 
RAM. The SLY40-XT Turbo also fea- 


tures up to 64K of ROM, a PC/XT key- 
board connector, an 8087 socket, and a se- 
rial port. 

For more information, contact Slicer, 
34509 Snelling Ave. South, Minneapolis, 
MN 55406; (612) 724-2710. 


OTHER HARDWARE 
PRODUCTS 


Co-Processor Controls Clock Rate 

Everest International Marketing Inc. has 
introduced Zipper, a 80287 math co-pro- 
cessor that can be set to its own optimal 
clock speed (up to 10.6 MHz) without 
changing crystals or math chip. The re- 
sulting acceleration of all programs that 
make constant calls to the chip is ideal for 
such applications as CAD/CAM/CAE 


| and spreadsheets. The Zipper board plugs 


right into the 80287 socket (no expansion 
board) and the existing chip is placed on 
the Zipper board. The Zipper can then 
control the 80287’s independent clock. 
With the Zipper is a software interface, 
the Zip-It utilities, that allow interactive 
control of the math chip’s clock speed. 

Zipper carries a suggested retail price of 
$159. For more information, contact Ever- 
est International Marketing, 633-470 
Granville St., Vancouver, British Colum- 
bia, V6C 1V5; (604) 684-4187. 


2.2 Gigs on One Cassette 

Emerald Systems has adapted helical-scan 
recording technology used in video record- 
ing and introduced VAST, Virtual Archival 
Storage Technology. The recording tech- 
nology uses the familiar approach to mag- 
netic recording but at greater data density 
and speed. Using helical scan, a disk can be 
backed up to tape at a speed of 15 Mbytes 
per minute. Emerald’s new VAST Device 
can store up to 2.2 Gbytes of data on a 
single tape cassette the size of a pocket cal- 
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COMPETITIVE EDGE 


1421 E. Goldsmith « Plymouth, MI 48170 « (313) 451-0665 


SPEED SHOP x: 


100% AT ™ COMPATIBLES 286’s & 386’s 
Velocity 286-12™ 12 MHZ, 1024K, 40MB, 28ms Hard Disk, EGA Card P/S/C 640 x 480. $2095. 
Velocity 286-10™ 10 MHZ, 1024K, 40MB, 28ms Hard Disk, EGA Card P/S/C ...... $1950. 
Velocity 386-16™ 16 MHZ, Reduced Foot Print, 1.2 Floppy, Size Case, 200 watt ... $1695. 
Velocity 386-20™ 20 MHZ, Many Options, 40MB, 28ms Hard Disk, EGA Card P/S/C . $3895. 


VELOCITY 286-XT AT POWER AT XT PRICE 


286-XT 6/8 MHZ 80286, 640K, 360K Floppy Zomb HD, Mono Monitor ......... $1295. 
286-XT 6/12 MHZ 80286 Operation, 640K, 360K Floppy, Zomb HD, Mono Monitor . . . $1395. 
8088-XT 4.77/8 MHZ 8088, 640K, 360K Floppy Zomb HD................. $ 995. 
Add $125 for 1.2 HB Floppy Option on 286-XT or 8088 XT ................ $ 125. 
Mitsubishi 19” Color Monitor 1024 x 768-6920 LPAG ................... 
Toshiba T3100 at Laptop — LiCmited Quantity. ...................... 


Hard Disks Available to 224 Megabytes on XT or AT™ Compatibles 


HARD DISK DRIVES MONITORS 
$7251, 40 MB, S9MS ac ve wwe a $495. NEC Mulfi Syné EGA «2.00 ye i $549. 
ST225, with XT Controller ...... $299. Samsung EGA 640x350 ....... $425. 
Miniscribe 6053 42MB 28ms_ ..... $679. Samsung Std. Color ......... $309. 
ST225 20MB, 65ms_ .......... $269. Samsung Amber Flat ......... $119. 
Miniscribe 7OMB, 28ms ........ $875. EGA Card, EGA, CGA, MPA... . $209. 
Toshiba 70OMB, 25ms ........ is CE EGA 640x480, 132 Column... . 


10 MHZ 80286 

$ 1.2 MB Floppy-Hard Disk/Floppy Controller, 640K 

a AS = A : Qos RAM, AT™ Style Keyboard Clock, 192 Watt Power 
a Supply, Set-Up Software, 1 Year Limited Warranty. 

NOVELL, ZENIX™, ALLOY SOLD & SUPPORTED 


12 MHZ 80286 Zenix System, 8 Serial, 1024K, 40MB, 28MS, EGA-640x480 . $3495. 
3 User Alloy Slave System, 10MHZ, 80286, 40MB, H.D.,1024K ........ $4195. 
2 User (2) AT Compatibles, 640K, 10MHZ, 80286’s, (1) 30MB, H.D. Novell 86 . $5295. 


2, 4, 8, 16, 31 USER SYSTEMS AVAILABLE 
S-100, All CompuPro®, Lomas, Teletek Boards at Lowest Prices. 


Desktop Publishing Systems and upgrades available. 


XT & AT are trademarks of International Business Machines. CompuPro is a registered trademark of VIASYN. Xenix is a trademark 
of MicroSoft. 


culator. Originally developed for high-end 
storage for desktop PCs (beyond 250 
Mbytes), but company sources say it is 
ideal for use with LANs and file services 
with disk volumes beyond 183 Mbytes. 


The VAST Device sells for $69.95, and 
cassettes are available in four sizes: 250 
Mbytes, 500 Mbytes, 1.0 Gbytes, and 2.2 
Gbytes. For more information, contact 
Emerald Systems Corp., 4757 Morena 
Blvd., San Diego, CA 92117; (619) 270- 
1994. 


Power Loss Shutdown 

Electronic Specialists have announced the 
PLS Power Loss Shutdown unit to protect 
microcomputers operating on UPS or SPS 
power supplies. It powers down the system 
if commercial AC power has not yet been 
restored when the UPS or SPS batteries 
have discharged. This prevents undesired 


POWER LOSS SHUTDOWN 


» . ww 
‘ 4 4 
INTERRUPT 


VOLTAGE 4 


computer and power system start-up after 
a power outage. Models with adjustable 
AC line drop-out voltage level also are 
available to accommodate the inherent 
brownout protection capabilities of most 
UPS systems. 

The PLS is $150 and is available from 
Electronic Specialists, Inc., 171 S. Main 
St., Natick, MA 01760; (800) 225-4876. 
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NEW SOFTWARE 
PRODUCTS 


SQL Applications for 286/386 
Oracle Corporation has _ released 
SQL*QMxX, a query and report writer that 
allows users of 286 and 386 machines to 
develop SQL-based applications under 
DOS 3.1+. The new product is a compati- 
ble superset of IBM’s Query Management 
Facility (QMF) and like QMF, provides a 
reporting and two query environments: 
Query-By-Example (QBE) and SQL com- 
mands. The easy-to-use report formatting 
capabilities also allow flexible presenta- 
tion of query results, either interactively or 
in hard copy. 

SQL*QMxX operates with IBM PCs run- 
ning Professional ORACLE and is priced 
at $395. For more information, contact 
Oracle Corp., 20 Davis Dr., Belmont, CA 
94002; (415) 598-8157. 


Lifeboat for Graphics Programmers 
All at C 

Lifeboat Associates has introduced a new 
graphics library for C programmers, Ad- 
vantage Graphics. According to Lifeboat 
executives, Advantage Graphics provides 
C programmers with an expanded, com- 
prehensive set of drawing functions, and 
the added performance necessary for de- 
signing multiple-window applications. The 
package also offers Advantage Plot, full 
support for a broad range of plotters. The 
Advantage Graphics library supports IBM 
PS/2 Models 30, 50, 60, and 80, as well as 
the PC/XT/AT. It is also compatible with 
a wide variety of C language compilers, 
including Lattice C, Microsoft C, and 
Borland Turbo C. 

The Advantage Graphics library is 
available for $250.00. For more informa- 
tion, contact Lifeboat Associates, 55 S. 
Broadway, Tarrytown, NY 10591; (914) 
332-1875. 


FORTRAN Programming Utilities 

Fortran Power Tools from PJN Interna- 
tional offers a collection of programming 
utilities to simplify program development 
on the PC. For example, the cross-refer- 
ence utility not only generates source code 
with detailed cross-referencing maps for 
variables, subprogram calls, and labels, 
but it also can scan multiple sources files 
to compile an alphabetical list of subpro- 


grams and tree diagrams of global 
routines. Other utilities in the library in- 
clude file print, routine extract, file ap- 
pend, case change, and more. 

Fortran Power Tools runs on IBM-com- 
patible systems with DOS 2.0 or higher. It 
is available for $119.95, plus $3.50 ship- 
ping and handling, from PJN Interna- 
tional, P.O. Box 200423, Austin, TX 
78720; (512) 258-1235. 


Easing Software Installation 

The Software Factory has created a new 
set of tools to assist application and soft- 
ware developers when installing new soft- 
ware. EZ-Install provides a thorough in- 
stallation program that offers more than 
printed installation instructions of .BAT 
files. EZ-Install allows the programmer to 
check disk and memory space, check files, 
check disk drives and directories, check 
DOS versions, and to give messages or 
take appropriate actions. 

Along with EZ-Install, The Software 
Factory has introduced EZ-Paint, screen 
painter that allows the end user to interact 
with your program through menus and 
forms. Using the screen-painting tech- 
nique, EZ-Paint provides control over 
foreground and background colors, color 
intensity, line font, field choices, text 
placement, menu choice threading, and 
other elements. 

EZ-Install is available for $99; EZ- 
Paint for $40. For more information, con- 
tact The Software Factory, 15301 Dallas 
Pkwy., Ste. 750, Dallas, TX 75248; (214) 
490-0835. 


Software Configuration 
Management Utility 

The Boston Software Works has released 
Version 6 of its BSW-Make software con- 
figuration management utility. Patterned 
after the UNIX-make utility, BSW-Make 
Version 6 automatically constructs pro- 
gram executables using information in a 
“makefile,” which assures developers that 
only those files that have been modified 
since the program was last built will be 
compiled or assembled and linked into a 
new program executable. The Version 6 is 
now available for PCs running MS-DOS/ 
PC-DOS, and for DEC VAX computers 
running VAX/VMS. 

BSW-Make Version 6 sells for $89.95 for 
MS-DOS. For more information, contact 
The Boston Software Works, 120 Fulton 
St., Boston, MA 02109; (617) 367-6846. 
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9-Track Tape Subsystem 
for the IBM PC/XT/AT 

XENIX or 
MS-DOS. 


The solution to your — 
micro/mainframe 
communications 
problem is 
available today! 


Qualstar’s new 
Yainch9-track |, 
MINISTREAMER brings full ANSI data interchange capability 
to the PC. Now you can exchange data files with virtually any 
other computer using 9-track tape. 


Available in both 7” and 101%” versions, the MINISTREAMER 
weighs in at only 27 pounds and uses less desk space than an 
ordinary sheet of paper, yet provides full 1600/3200 BPI 
capability at an affordable price. Up to 134 megabytes of data 
(depending on format) can be stored on a standard 1014” reel of 
tape, thus making the MINISTREAMER a highly-reliable answer 
to your backup requirements as well. 


Tape subsystem includes tape drive, coupler card, cables, 
dust-cover and MS-DOS or XENIX compatible software. 
Prices start at $2,995. 


386 READY! 


Discover the many advantages 
9-track tape has over other 
Micro/Mainframe links. 


Call us today! 


tz ; i [JURLSTAR, 


9621 Irondale Avenue, 
Chatsworth, CA 91311 
Telephone: (818) 882-5822 


MULTITASKING 
AND MULTIUSER 

PERFORMANCE 
FOR 27¢ PER DAY 


With OPERATING SYSTEM TOOLBOX, the Software 
Construction set that allows you to build your own custom 
operating system. 

With PENX, Wendin's PC version of Bell Laboratories’ 
incredible UNIX Operating System. 

With PCWMS, A system similar to the VAX/VMS 
Mainframe Operating System that brings an elegant set of 
services to the PC. 


FROM WENDIN ... of course! 


EACH PRODUCT IS PRICED AT ONLY $99.00, 
AND INCLUDES SOURCE CODE ON DISK. 
If you average that cost out, that's only 27¢ per day for one year. 
THE REST OF YOUR LIFE IT’S FREE! 


* * « MENTION WHERE YOU SAW THIS AD * * * 
WHEN YOU ORDER AND RECEIVE FREE A 


HIGH QUALITY PEN AND PENCIL SET IN A DELUXE GIFT BOX 
COMPLIMENTS OF WENDIN. 


ORDER HOTLINE 
(509) 624-8088 


® 
Vi BOX 3888 
SPOKANE, WA 99220-3888 


Working beyond the horizon to develop the operating systems of tomorrow 
© Copyright 1987 Wendin, Inc. (509) 624-8088 


Wendin is a reqistered trademark of 
Wendin. Inc. PNX. PCVMS. and 
Operating System Toolbox, are 
trademarks of Wendin, Inc. 
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HIGH PERFORMANCE RAM 


256 K CMOS STATIC RAM 
LITHIUM BATTERY BACKUP 


Compupro 
Ram 22 


Octagon 
256K 


Cromemco 
256KZ II 


Dynamic 
Boards 


BG-Bank 
2568S 


IN YOUR SYSTEM 
CROMIX-D e MPM e CCS e OASIS e AMOS 


Vv PLUS: 8/16 BIT TRANSFERS e 24-BIT EX. ADDRESSING 
8-12 MHZ @ 2K DESELECTS e RAM-EPROM MIX 
IEEE 696/S-100 e LOW POWER e FULLY STATIC 


LITHIUM BATTERY BACKUP avoids power failure crashes intel- 
ligently. Unique POWER-FAIL-SENSE circuit allows processor 
to save register information and disable board before POWER 
FAILURE CRASHES memory. 


Battery Backup 
Battery Backup 


BG BANK 256S $329 
BG BANK 64S $249 


BG COMPUTER APPLICATIONS, 206 Brookside, 
Bryan, Texas 77801. International orders add 30%. 


(409) 775-5009 
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Classifieds 


Micro/Systems Journal accepts Classified Ads. 
The charge is $6/line (3 lines minimum, 7 lines 
maximum); 40 characters max./line. Three 
times frequency $15/line; six times $25/line; 
non-profit clubs $2/line. Logos, special type, 
etc. are extra charge. Check must accompany 
ad copy. Send to M & T Publishing Inc., 501 
Galveston Dr., Redwood City, CA 94063. 


DOS User’s Group 

Quarterly Newsletter discounts on Third Party 
Products. Latest DOS news, demo diskettes. 
DOS Tutorials. Annual membership fee: U.S. 
$25, Canada & Europe $35. DOS User’s Group, 
P.O. Box 26601, Las Vegas, NV 89126. 


ENGINEERING SOFTWARE 

Circuit Design and Analysis Programs. FREE 
CATALOG and TUTORIAL GUIDE. BV Engi- 
neering, 2200 Business Way, #207, Riverside, 
CA 92501; (714) 781-0252. 


RAM DISK 

S-100, 2 MEG, PORT I/O. New, Warranteed, 
$725. S. Lugert, 439 Peck Slip Sta., N.Y.C., 
N.Y. 10272, or call (718) 622-0654. 


DISK CONVERSION: Most CP/M and MS- 
DOS formats. 48 hour turnaround. Reasonable 
rates. Personal service. For information call or 
write: RH Associates, 2211 Mark Ct., Silver 
Spring, MD 20910; (301) 587-6230. 


Listings are available 
on disk 


Why spend hours reinputting the 
proven programs we print? The 
source code that accompanies the 
articles published in Micro/Systems 
Journal is available on MS-DOS 
disk. If you are interested in any 
of the programs offered in this 
issue, or want more information 
about programs from past issues, 
please feel free to contact us. 
Please be sure to specify the issue. 
To order sent $14.95 to: 


Micro/Systems Journal 
501 Galveston Dr. 
Redwood City, CA 94063 
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SQL.PAS 

Make stack, queue, and list standard data types 
in Turbo Pascal ($9.95). PSW, Box 10072, 
McLean, VA 22102-8072. 


Compupro 816A, S-100, 88/85, 256K, 512K 
Mdrive, 2-8” Qumes, Wyse 100, Hayes 300, 
Pascal MT +86, Aztec C86, Vedit 80/86, MS- 
Basic 80, dBASE, SuperCalce, 2000 hrs, 
$2,500. Neil (404) 255-8007. 


Compupro 8/16 S-100 SYSTEM, Disk 1A SS1 
CPU 85/88, 576k, IF4, 2-8” ‘ht drives, TV1 
970 terminal. CP/M-816, C-DOS, much soft- 
ware $2,500/offer. Steve (919) 481-1300. 


Multiline TBBS 

No busys. Doors include download on first call, 
electronic mail, multiple sigs, CB chat. North 
county San Diego non-profit group has remote 
access nodes 24 hours, 300/1200/2400 bps. 
Line #1: (619) 749-2741; #2: 749-2589; #3: 
566-6329; #4: 727-0202; #5: 749-8465. Voice: 
749-0322. 


KAYPRO ’83, XEROX 820-I, AND BIG 
BOARD-I owners—Blazing fast assembly lan- 
guage device drivers provide windows, sprites, 
mouse support, and more. ONLY $49.95 
FLEXISOFT, 3987 Valley View Dr., Ashland, 
KY 41101; (606) 325-3736. 


C VIDEO TAPE 

Unlock the secrets of C! See source code exam- 
ples reveal every nook and cranny of K&R. 6- 
hour tape takes you from novice to expert. Re- 
view it again and again. Good for reference. 
Comes with book; $39.95. Applied Logic, 2309 
Royce Dr., Arlington, TX 76016; (817) 275- 
4631. 


FOR SALE: Compupro 816/C system with 286 
CPU and 1MB memory, 16 ports, 20MB car- 
tridges, 5 Wyse terminals, lots of software. Best 
Offer. (312) 393-2900. 


S-100. Lomas based MS-DOS. | sys, upgraded 
Vector MZ, more. Gary Van Cott, Box 1879, 
Grafton, VA 23692. (804) 898-3680. 


Advertiser Index 


Aker) Corporation 2:5.220es awnaecee cts 
Alloy Computer Products a 
Applied Mia pi Geers cs chseaysteasssencouteamsineosnes 
AUStin COMCAWOTKS 28 neces sere seicseaeecsceies 
BG Computer Applications ... 79 
Blaise Computing Inc. ey) 
BV Engineering.......... .80 
Clary, Corporation 5225 ociccte serene cere ctaeet 55 
Gomipetitive;-Edgei ts ene ech cera artos 77 
CompuPro/ Viasyn..... ae) 
Concurrent Research .... 73. 
Davidge Corporation.. .67 
Digiboard sc sic. accuser ce eens 31 
Digital Research Computers .......................... 27 
DOS User’s Group 
EchelomilinGsc gsi cccsesssthc spices etna 
ECOSOLGEINOS 25 oo25, cdacadsta caer ote ere ene 5 
Entelekon..... ae | 


Exec-PC Ine. 


Flexisoft .......... .80 
Gary Van Cott. 25 ocd ecscctcev ng eerernesd 80 
Gimpeliiass ee ee aaa cd dec cecal 32 
Goodall Computer Systems... wed 
Harvard Softworks .............0.:0:eccceseeeseeseeeee 36 
Hawkeye! Grafixlne. ie ascn tessa cesttesssettesese 61 
House Sub. Ad. .................00-006 24,56 


Integrand Research Corporation... 


Intercontinental Microsystems .... 35 
Lahey Computer Systems Ine. .................-..... 11 
Lodden Technology Limited........0..0..0....000.. 69 
Macrotech International... .-C-2 
MetaWare Ine. ........:......----+- 

Night Owl 


NWP Intelligent Solutions, Ine.....................- 60 
Opt-Tech Data Processing..................::020000 67 
Paul Black Associates ....... -.-61 
PD-SIG: THE TIBBS ... 2.80 
PORE CHR ee ee Rae 
Periscope Coisines).:secices 2. ccstenccseeeceeces 715 
Power: Soltwareic.cicssrcecisarse marae 
Programmer’s Connection . 

Programmer’s Paradise ................00c0:ceceeeree 
Programmer’s Shop ..........-2..20.c0:cccsceeeseeseesees 
Qualstar Corporation......... ee 
Quarterdeck Office Supplies.. 

Raima Corporation............ 


Stephen’ Re Wound 720.0005 srs ccesscesacivereceececctvers 80 
Stony Brook Software, Ine. ...........0..02..eee 61 
Sunny Hill Software 


Whitewater Group .. vs 
Wyte Corporation: )3-cnc. cones casssecenceees 


Micro/Systems JOURNAL NOVEMBER / DECEMBER 1987 


How to tell the difference 


between DESQview 2.0 and 
any other environment. 


Seeecting DESQview, 
the environment of 
choice, can give you the 
productivity and power 
you crave, without the 
loss of your old pro- 
grams and hardware. 

If you like your existing 
programs, want to use 
them together, transfer 
data between them, 
print, sort, communi- 
cate with or process- 
in-background, yet still 
have the need to keep 
in place your favorite 
PC(8088, 8086, 80286 
or 80386), DESQview 
is the “proven true” 
multitasking, multi- 
windowing environ- 
ment for you. Best of all, DESQview 2.0 is here now, 
with all the money saving, time saving, and productiv- 
ity features that others can only promise for the all- 
too-distant future. 

And with DESQview’s new graphics enhancements 
for Hercules, CGA, EGA, and VGA, Version 2.0 still 
offers the same award winning and pioneering fea- 
tures for programs that earned DESQview its leader- 
ship, only now you can also run desktop publishing 
programs, CAD programs, even GEM-™' Topview-™' and 
Microsoft Windows-™ specific programs. In some cases 
you'll add as little as 1O-40K to your system overhead. 
Now you can have multi-tasking, multi-windowing, 
break the 640K habit too and still get an auto dialer, 
macros, menus for DOS and, for advanced users, a new 
complete application programmer’s interface capabil- 
ity. No wonder that over the years, and especially in 
recent months, DESQview, and now 
DESQview 2.0 have earned extrava- 
gant praise from some of the most 
respected magazines in the industry. 

“Product of the Year” by readers 
vote in InfoWorld. 

“Best PC Environment” by popu- 
lar vote at Comdex Fall in PC Tech 
Journal's “System Builder” Contest. 

“—T wouldn't want to run an IBM 


INFO 
WORLD 


REPORT CARD 
DESQview 2.0 


One picture is worth a thousand promises. 


or compatible 
computer without 
DESQview’—Info- 
World, Michael Miller. 
“A colossus among 
windowing environ- 
ments”... “will run 
almost anything’—PC 
Week, Marvin Bryan. 
“Windows, prom- 
ises, but DESQview 
delivers’—MICRO- 
TIMES, Birell Walsh. 
No other environ- 
ment has consistently 
pioneered features, open- 
ness, and productivity. 
See for yourself. Send in 
the coupon. The possi- 
bilities are endless with 
DESQview 2.0. 
Attention Programmers: For more information 
about Quarterdeck’s API, and future 386 program 
extensions, call us today. 
SYSTEM REQUIREMENTS 
IBM Personal Computer and 100% compatibles (with 8086, 8088, 80286 or 80386 
processors) with monochrome or color display; IBM Personal System/2 * Memory: 640K 
recommended; for DESQview itself 0-145K * Expanded Memory (Optional): expanded 
memory boards compatible with the Intel AboveBoard; enhanced expanded memory 
boards compatible with the AST RAMpage « Disk: Two diskette drives or one diskette 
drive and a hard disk * Graphics Card (Optional): Hercules, IBM Color/Graphics (CGA), 
IBM Enhanced Graphics (EGA), IBM Personal System/2 Advanced Graphics (VGA) « 
Mouse (Optional): Mouse Systems, Microsoft and compatibles * Modem for Auto-Dialer 
(Optional): Hayes or Compatible + Operating System: PC-DOS 2.0-3.3; MS-DOS2.0-3.2 + 
Software: Most PC-DOS and MS-DOS application programs; programs specific to 


TopView 1.1, GEM 1.1 and Microsoft Windows 1.03 + Media: DESQview 2.0 is available 
on either 514" or 344" floppy diskettes 


—=In-a-Vision 


Help for 
Quit DE 


| Rush me DESQview 2.0! Today! 
No. ¢ 


of Copies Media 342/514" Product 
| DESQview 2.0 


Retail Price ea. 
$129.95 $ 


‘Total 
Shipping & Handling USA $ 5.00 
Outside USA | $ 10.00 


al | 
$ | 
Sales Tax (CA residents) | 6.5% $ 
Amount $ | 
[(JAMEX [Check Enclosed a 


Payment: [] Visa ([]MC 

Credit Card: Valid Since ________/ Expiration ——_/_ 
Card Number: [ L] | mi | | T] | | | | | | 
Credit Card Name. " - 

Shipping Address = | 
City. State Zip Telephone 


NOTE: If you own DESQview call us for a special upgrade offer, or send in your DESQview 
registration card, AST Special Edition users included. 
ee et 


| Mail to: Quarterdeck Office Systems, 150 Pico Boulevard, Santa Monica, CA 90405. 


DS9 


Quarterdeck 


Quarterdeck Office Systems * 150 Pico Boulevard, Santa Monica, CA 90405 * (213) 392-9851 


DESQview is a trad 
trademarks of Inte; 


ark of Quarterdeck Office Systems. AboveBoard is a trademark of Intel Corporation. Hayes is a trademark of Hayes MicroComputer Products Inc. IBM, PC, Personal System/2 and TopView are 
ional Business Machines Corporation, Microsoft Windows and MS are registered trader 


ks of Microsoft Corporation. Mouse Systems is a trademark of Metagraphics/Mouse Systems. RAMpage 


is a trademark of AST Research, Inc. GEM is a trademark of Digital Research. Hercules is a trademark of Hercules. 
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_PC-PLUS’ “&s 
High Performance 
Network Solutions 


Unlike traditional LANs, PC-PLUS’ on-the-bus 
architecture puts the computing power where you need it 
— with the data — inside the server. 


PC-PLUS: The LAN 


Engineered for Shared Data 


Any local area network can con- 
nect PCs. PC-PLUS, however, is 
engineered to optimize multiuser 
access to shared databases. We 
put a PC — or AT — onacard 
that plugs into the server. Putting 
your computing power on the 
same bus as your data. Giving 
you high bandwidth where you 
need 1t. Without the transmis- 
sion overhead that steals per- 
formance on most LANs. 


PC-PLUS Gives You the 


Power You Need 


Our plug-in cards come as 
8 MHz PCs or 8 MHz ATs 
— to match your comput- 
ing needs exactly. And 
PC-PLUS networks can 
deliver that power — proven 
by benchmarks. Power to 
get your job done. Power 
to grow into new applica- 
tions without sacrificing 
performance. 


PC-PLUS is 
Easy to 
Install and Use 


We put the computing 
engines all in one place 
— in the server. Not 
spread all over the build- 
ing. And our LAN soft- 
ware is truly easy to in- 
stall. Use PC-PLUS with 
your choice of AT compatible 
servers or with Personal 
System/2™ Add a card and ter- 
minal to grow. Simple RS-232 
twisted-pair data cables — no ex- 
pensive rewiring with coax. You 
can often use existing telephone 
cable. Convenient packaged solu- 
tions, including Alloy’s NTNX™ 
network software. 


PC-PLUS Runs With 
Personal System/2 


With Alloy’s new HI/2™ Micro 


Channel™ interface, you can 
connect PC-PLUS to IBM’s new 
Personal System/2 Model 50, 60 
or 80 computers. Use Alloy’s 4, 


— /llLOy 
PC-PLUS 


8, 12 or 16 slot expansion boxes 
to build PC-PLUS networks with 
PS/2 file servers. Or choose our 
PLUS4/PS for a simple, precon- 
figured 4 workstation network. 


PC-PLUS: Find Out Before 
You Invest 


A local area network is a long 
term investment. Today’s appli- 
cations are just the beginning. 
Make sure your choice is ready 
for tomorrow — with mainframe 
connections, remote access, 
graphics and the power for grow- 
ing database applications. To 
find out more about PC-PLUS, 
call or write Alloy today at 

(617) 875-6100. 


PC-PLUS” 
The No-Nonsense 
| Network 


COMPUTER PRODUCTS 


Alloy Computer Products, Inc., 100 Pennsylvania Avenue, Framingham, Massachusetts 01701. (617) 875-6100, TWX: 710-346-0394 
Alloy Computer Products, Inc., 9 Executive Circle, Suite 240, Irvine, California 92714. (714) 261-7661 
In Europe: Alloy Computer Products (Europe) Ltd., Tel. 0285-69571, Tlx: 43340 In Australia: Alloy Australia Pty. Ltd., Tel. 011-613-561-4988 


